Sql Server int vs nvarchar Vergleich der Leistung?

7

Für Ihre Datenbankdesign / Performance-Gurus da draußen.

Ich entwerfe eine Tabelle, ich habe die Wahl, entweder int oder nvarchar (128) für eine Spalte zu verwenden, nehme an, dass Platz kein Problem ist. Meine Frage ist, welche Leistung geben wird

wenn ich mit der int-Spalte

suche

where ID = 12324

oder wenn ich mit der nvarchar-Spalte suche (der Schlüssel ist der gesamte Wert, also verwende ich nicht den LIKE-Operator)

where Key = 'my str'

Ich bin mir sicher, dass es für kleinere Datensätze keine Rolle spielt, aber nehmen wir an, dass diese Daten in Millionen von Zeilen vorkommen.

    
Ray Fan 19.07.2010, 19:25
quelle

4 Antworten

17

INT wird schneller sein - hier ist der Grund:

  • SQL Server organisiert seine Daten und Indizes in Seiten von 8K
  • Wenn Sie eine Indexseite mit INT-Taste haben, erhalten Sie ca. 2'000 INT-Einträge
  • Wenn Sie NVARCHAR (128) verwenden und durchschnittlich 20 Zeichen verwenden, sind dies 40 Byte pro Eintrag oder ungefähr 200 Einträge pro Seite

Für die gleiche Anzahl von Indexeinträgen würde der Fall NVARCHAR (128) zehnmal so viele Indexseiten verwenden.

Das Laden und Durchsuchen dieser Indexseiten wird erheblich mehr E / A-Vorgänge erfordern.

Um die Dinge kurz zu machen: Wenn du kannst, benutze immer INT.

    
marc_s 19.07.2010, 19:33
quelle
8

Leerzeichen ist immer ein Problem in Datenbanken. Breitere Schlüssel bedeuten weniger Einträge pro Seite, mehr gescannte Seiten, um Werte zu aggregieren und zu summieren, bedeutet mehr IO, weniger Leistung. Bei Clustered-Indizes wird dieses Problem mit jedem nicht gruppierten Index multipliziert, da sie den Suchschlüssel (Clusterschlüssel) in ihren Blättern reproduzieren müssen. Daher ist ein Schlüssel vom Typ nvarchar(128) immer fast immer schlechter als ein INT.

Verwenden Sie andererseits keine INT-Taste, wenn dies nicht angemessen ist. Verwenden Sie immer den entsprechenden Schlüssel, unter Berücksichtigung Ihrer Abfragen . Wenn Sie immer nach einem nvarchar (128) -Spaltenwert abfragen, ist möglicherweise ein guter geclusterter Schlüsselkandidat. Wenn Sie aggregieren mit dem nvarchar (128) -Schlüssel, dann ist wahrscheinlich ein guter geclusterter Schlüsselkandidat.

    
Remus Rusanu 19.07.2010 19:33
quelle
5

Das Hauptproblem bei der Leistung ist die Größe des Feldes - ein int ist 4 Bytes, wohingegen ein nvarchar(128) 254 Bytes ist.

All dies muss vom SQL-Server verwaltet werden, so dass die Verwaltung von int viel schneller ist als die von nvarchar(128) .

    
Oded 19.07.2010 19:33
quelle
0

Ich würde den int für die Leistung verwenden (wenn dies besonders Joins erfordert) und einen eindeutigen Index auf den möglichen natürlichen Schlüssel für die Datenintegrität setzen.

    
HLGEM 19.07.2010 21:52
quelle
yii\base\ErrorException
Copied! Copy Stacktrace Search Stackoverflow Search Google Error

PHP Core Warningyii\base\ErrorException

PHP Startup: Unable to load dynamic library 'mongodb.so' (tried: /usr/lib64/php/modules/mongodb.so (/usr/lib64/php/modules/mongodb.so: cannot open shared object file: No such file or directory), /usr/lib64/php/modules/mongodb.so.so (/usr/lib64/php/modules/mongodb.so.so: cannot open shared object file: No such file or directory))

$_GET = [
    'id' => '409595',
    'url' => 'sql-server-int-vs-nvarchar-comparison-on-performance',
];

$_SESSION = [
    '__flash' => [],
];