Schätzen der Größe eines nicht gruppierten Indexes
Mithilfe der folgenden Schritte können Sie abschätzen, wie viel Speicherplatz zum Speichern eines nicht gruppierten Indexes benötigt wird.
- Berechnen des Speicherplatzes, der zum Speichern der Indexinformationen in den Nichtblattebenen des nicht gruppierten Indexes erforderlich ist.
- Berechnen des Speicherplatzes, der zum Speichern der Indexinformationen in der Blattebene des nicht gruppierten Indexes erforderlich ist.
- Addieren der berechneten Werte.
Schritt 1. Berechnen des Speicherplatzes, der zum Speichern der Indexinformationen in den Nichtblattebenen verwendet wird
Wichtig: |
---|
Notieren Sie sich die in diesem Schritt verwendeten Werte, um sie für Schritt 2 bereitzuhalten. |
Mit den folgenden Schritten können Sie den Umfang des Speicherplatzes schätzen, der zum Speichern der oberen Ebenen des Indexes erforderlich ist.
- Geben Sie die Anzahl der Zeilen an, die die Tabelle enthalten wird:
Num_Rows = Anzahl der Zeilen in der Tabelle - Geben Sie die Anzahl der Spalten mit fester und mit variabler Länge im Indexschlüssel an, und berechnen Sie den Speicherplatz, der für deren Speicherung erforderlich ist:
Die Schlüsselspalten eines Indexes können Spalten fester und variabler Länge enthalten. Um die Größe der Indexzeilen auf der inneren Ebene zu schätzen, müssen Sie den Speicherplatz berechnen, der von jeder dieser Spaltengruppen innerhalb der Indexzeile belegt wird. Die Größe einer Spalte hängt von der Angabe für Datentyp und -länge ab. Weitere Informationen finden Sie unter Datentypen (Datenbankmodul).
Num_Key_Cols = Gesamtanzahl der Schlüsselspalten (fester Länge und variabler Länge)
Fixed_Key_Size = Gesamtanzahl der Byte in allen Schlüsselspalten fester Länge
Num_Variable_Key_Cols = Anzahl der Schlüsselspalten variabler Länge
Max_Var_Key_Size = Maximale Bytegröße aller Schlüsselspalten variabler Länge - Berücksichtigen Sie auch den Datenzeilenlokator, der erforderlich ist, wenn der Index nicht eindeutig ist:
Wenn der nicht gruppierte Index nicht eindeutig ist, wird der Datenzeilenlokator mit dem Schlüssel des nicht gruppierten Indexes kombiniert, um einen eindeutigen Schlüsselwert für jede Zeile zu erstellen.
Wenn sich der nicht gruppierte Index über einem Heap befindet, ist der Datenzeilenlokator die Heap-RID. Die Größe beträgt dann 8 Byte.
Num_Key_Cols = Num_Key_Cols + 1
Num_Variable_Key_Cols = Num_Variable_Key_Cols + 1
Max_Var_Key_Size = Max_Var_Key_Size + 8
Wenn sich der nicht gruppierte Index über einem gruppierten Index befindet, dann ist der Datenzeilenlokator der Gruppierungsschlüssel. Bei den Spalten, die mit dem nicht gruppierten Index kombiniert werden müssen, handelt es sich um die im Gruppierungsschlüssel enthaltenen Spalten, die noch nicht in der Menge der nicht gruppierten Indexschlüsselspalten vorhanden sind.
Num_Key_Cols = Num_Key_Cols + Anzahl der Gruppierungsschlüsselspalten, die nicht in der Menge der nicht gruppierten Indexschlüsselspalten vorhanden sind (+ 1, wenn der gruppierte Index nicht eindeutig ist)
Fixed_Key_Size = Fixed_Key_Size + Gesamtanzahl der Byte in allen Generierungsschlüsselspalten fester Länge, die nicht in der Menge der nicht gruppierten Indexschlüsselspalten vorhanden sind.
Num_Variable_Key_Cols = Num_Variable_Key_Cols + Anzahl der Gruppierungsschlüsselspalten variabler Länge, die nicht in der Menge der nicht gruppierten Indexschlüsselspalten vorhanden sind (+ 1, wenn der gruppierte Index nicht eindeutig ist)
Max_Var_Key_Size = Max_Var_Key_Size + maximale Anzahl der Byte in den Gruppierungsschlüsselspalten variabler Länge, die nicht in der Menge der nicht gruppierten Indexschlüsselspalten vorhanden sind (+ 4, wenn der gruppierte Index nicht eindeutig ist) - Ein Teil der Zeile, der als NULL-Bitmuster bezeichnet wird, kann für das Verwalten der NULL-Zulässigkeit der Spalte reserviert sein. Berechnen Sie dessen Größe:
Wenn der Indexschlüssel Spalten enthält, die NULL-Werte zulassen (einschließlich erforderlicher Gruppierungsschlüsselspalten wie in Schritt 1.3 beschrieben), ist ein Teil der Indexzeile für das NULL-Bitmuster reserviert.
Index_Null_Bitmap = 2 + ((Anzahl der NULL-zulässigen Schlüsselspalten + 7) / 8)
Nur der ganzzahlige Teil des vorherigen Ausdrucks darf verwendet werden. Der Rest wird verworfen.
Wenn keine Spalten vorhanden sind, die NULL-Werte zulassen, legen Sie Index_Null_Bitmap auf 0 fest. - Berechnen Sie die Größe der Daten variabler Länge:
Wenn der Indexschlüssel Spalten variabler Länge enthält (einschließlich erforderlicher Schlüsselspalten des gruppierten Indexes), müssen Sie ermitteln, wie viel Speicherplatz zum Speichern der Spalten innerhalb der Indexzeile verwendet wird:
Variable_Key_Size* = 2 + (Num_Variable_Key_Cols x 2) + *Max_Var_Key_Size Bei dieser Formel wird angenommen, dass alle Spalten variabler Länge zu 100 % gefüllt sind. Wenn sich abzeichnet, dass ein niedrigerer Prozentsatz des Speicherplatzes für Spalten variabler Länge verwendet wird, können Sie den Max_Var_Key_Size-Wert mithilfe dieses Prozentsatzes anpassen, um einen genaueren Schätzwert für die Gesamtgröße der Tabelle zu erhalten.
Wenn keine Spalten variabler Länge vorhanden sind, legen Sie Variable_Key_Size auf 0 fest. - Berechnen Sie die Länge der Indexzeile:
Index_Row_Size = Fixed_Key_Size + Variable_Key_Size + Index_Null_Bitmap + 1 (für Zeilenüberschriftenaufwand einer Indexzeile) + 6 (für ID-Zeiger der untergeordneten Seite) - Berechnen Sie die Anzahl der Indexzeilen pro Seite (8096 freie Byte pro Seite):
Index_Rows_Per_Page = 8096 / (Index_Row_Size + 2)
Da sich eine Indexzeile nicht auf zwei Seiten erstreckt, muss die Anzahl der Indexzeilen pro Seite auf die nächste ganze Zeile abgerundet werden. Die Angabe 2 in der Formel bezieht sich auf den Eingang der Zeile in das Slotarray der Seite. - Berechnen Sie die Anzahl der Ebenen im Index:
Levels = 1 + log Index_Rows_Per_Page (Num_Rows / Index_Rows_Per_Page)
Beachten Sie, dass dieser Wert die Blattebene des nicht gruppierten Indexes nicht enthält. - Berechnen Sie die Anzahl der Seiten im Index:
Num_Index_Pages = ?Level (Index_Rows_Per_Page)Level – 1
wobei 1 <= Level <= Levels
Nehmen Sie als einfaches Beispiel einen Index an, in dem die Gesamtanzahl der Indexzeilen, die auf der Ebene über der Blattebene erforderlich sind, 1000 beträgt, und 10 Indexzeilen auf eine Seite passen. Dies bedeutet, dass 100 Seiten zum Speichern dieser 1000 Zeilen erforderlich sind. Die nächste Ebene des Indexes muss 100 Zeilen speichern. Dies bedeutet, dass 10 Seiten erforderlich sind. Die letzte Ebene des Indexes muss 10 Zeilen speichern. Dies bedeutet, dass eine Seite erforderlich ist. Wenn Sie diese Werte in den oben genannten Formeln verwenden, ergibt sich Folgendes:
Height = 1 + log10 (1000 / 10) = 3
Num_Index_Pages = (10)3-1 + (10)2-1 + (10)1-1 = 111, was der Anzahl der im Beispiel beschriebenen Seiten entspricht. - Berechnen Sie die Größe des Indexes (insgesamt 8192 Byte pro Seite):
Index_Space_Used* = 8192 x *Num_Index_Pages
Schritt 2. Berechnen des Speicherplatzes, der zum Speichern der Indexinformationen in der Blattebene verwendet wird
Mit den folgenden Schritten können Sie den Umfang des Speicherplatzes schätzen, der zum Speichern der Blattebene des Indexes erforderlich ist. Sie benötigen die in Schritt 1 aufgezeichneten Werte, um diesen Schritt durchführen zu können.
- Geben Sie die Anzahl der Spalten mit fester und mit variabler Länge auf Blattebene an, und berechnen Sie den Speicherplatz, der für deren Speicherung erforderlich ist:
Hinweis: In SQL Server 2005 kann ein nicht gruppierter Index erstmals erweitert werden, indem Nichtschlüsselspalten zusätzlich zu Indexschlüsselspalten eingeschlossen werden. Diese zusätzlichen Spalten werden auf der Blattebene des nicht gruppierten Indexes gespeichert. Weitere Informationen finden Sie unter Erstellen von Indizes mit eingeschlossenen Spalten. Hinweis: In SQL Server 2005 können varchar-, nvarchar-, varbinary- oder sql_variant-Spalten mit der Auswirkung kombiniert werden, dass die definierte Tabellengesamtbreite größer als 8.060 Byte ist. Die Länge jeder einzelnen Spalte unterliegt auch weiterhin der Beschränkung von 8.000 Byte für eine varchar-, varbinary- oder sql_variant-Spalte und von 4.000 Byte für nvarchar-Spalten. Die kombinierte Breite kann jedoch den Grenzwert von 8.060 Byte in einer Tabelle überschreiten. Dies gilt auch für die Zeilen auf Blattebene eines nicht gruppierten Indexes, die eingeschlossene Spalten enthalten. Weitere Informationen finden Sie unter Zeilenüberlauf bei Daten über 8 KB.
Num_Leaf_Cols* = *Num_Key_Cols
Fixed_Leaf_Size* = *Fixed_Key_Size
Num_Variable_Leaf_Cols* = *Num_Variable_Key_Cols
Max_Var_Leaf_Size* = *Max_Var_Key_Size
Wenn der nicht gruppierte Index keine eingeschlossenen Spalten besitzt, fügen Sie die entsprechenden Werte den Werten aus Schritt 1 einschließlich allen Änderungen, die ggf. in Schritt 1.3 vorgenommen wurden, hinzu. Die Größe einer Spalte hängt von der Angabe für Datentyp und -länge ab. Weitere Informationen finden Sie unter Datentypen (Datenbankmodul).
Num_Leaf_Cols = Num_Key_Cols + Anzahl der enthaltenen Spalten
Fixed_Leaf_Size = Fixed_Key_Size + Gesamtanzahl der Byte der aufgenommenen Spalten fester Länge
Num_Variable_Leaf_Cols = Num_Variable_Key_Cols + Anzahl der aufgenommenen Spalten variabler Länge
Max_Var_Leaf_Size = Max_Var_Key_Size + maximale Anzahl der Byte der aufgenommenen Spalten variabler Länge
2. Konto für den Datenzeilenlokator:
Wenn der nicht gruppierte Index nicht eindeutig ist, wurde der Aufwand für den Datenzeilenlokator bereits in Schritt 1.3 berücksichtigt. In diesem Fall sind keine zusätzlichen Änderungen erforderlich. Fahren Sie mit dem nächsten Schritt fort.
Wenn der nicht gruppierte Index eindeutig ist, muss der Datenzeilenlokator in allen Zeilen auf der Blattebene berücksichtigt werden.
Wenn sich der nicht gruppierte Index über einem Heap befindet, ist der Datenzeilenlokator die Heap-RID (Größe 8 Byte).
Num_Leaf_Cols = Num_Leaf_Cols + 1
Num_Variable_Leaf_Cols = Num_Variable_Leaf_Cols + 1
Max_Var_Leaf_Size = Max_Var_Leaf_Size + 8
Wenn sich der nicht gruppierte Index über einem gruppierten Index befindet, dann ist der Datenzeilenlokator der Gruppierungsschlüssel. Bei den Spalten, die mit dem nicht gruppierten Index kombiniert werden müssen, handelt es sich um die im Gruppierungsschlüssel enthaltenen Spalten, die noch nicht in der Menge der nicht gruppierten Indexschlüsselspalten vorhanden sind.
Num_Leaf_Cols = Num_Leaf_Cols + Anzahl der Gruppierungsschlüsselspalten, die nicht in der Menge der nicht gruppierten Indexschlüsselspalten vorhanden sind (+ 1, wenn der gruppierte Index nicht eindeutig ist)
Fixed_Leaf_Size = Fixed_Leaf_Size + Anzahl der Byte in allen Generierungsschlüsselspalten fester Länge, die nicht in der Menge der nicht gruppierten Indexschlüsselspalten vorhanden sind.
Num_Variable_Leaf_Cols = Num_Variable_Leaf_Cols + Anzahl der Gruppierungsschlüsselspalten variabler Länge, die nicht in der Menge der nicht gruppierten Indexschlüsselspalten vorhanden sind (+ 1, wenn der gruppierte Index nicht eindeutig ist)
Max_Var_Leaf_Size = Max_Var_Key_Size + Anzahl der Byte in den Gruppierungsschlüsselspalten variabler Länge, die nicht in der Menge der nicht gruppierten Indexschlüsselspalten vorhanden sind (+ 4, wenn der gruppierte Index nicht eindeutig ist)
3. Berechnen der Größe des NULL-Bitmusters:
Leaf_Null_Bitmap = 2 + ((Num_Leaf_Cols + 7) / 8)
Nur der ganzzahlige Teil des vorherigen Ausdrucks darf verwendet werden. Der Rest wird verworfen.
4. Berechnen Sie die Größe der Daten variabler Länge:
Wenn der Indexschlüssel Spalten variabler Länge enthält (einschließlich erforderlicher Grupppierungsschlüsselspalten wie zuvor in Schritt 2.2 beschrieben), müssen Sie ermitteln, wie viel Speicherplatz zum Speichern der Spalten innerhalb der Indexzeile verwendet wird:
Variable_Leaf_Size* = 2 + (Num_Variable_Leaf_Cols x 2) + *Max_Var_Leaf_Size
Bei dieser Formel wird angenommen, dass alle Spalten variabler Länge zu 100 % gefüllt sind. Wenn sich abzeichnet, dass ein niedrigerer Prozentsatz des Speicherplatzes für Spalten variabler Länge verwendet wird, können Sie den Max_Var_Leaf_Size-Wert mithilfe dieses Prozentsatzes anpassen, um einen genaueren Schätzwert für die Gesamtgröße der Tabelle zu erhalten.
Wenn keine Spalten variabler Länge vorhanden sind, legen Sie Variable_Leaf_Size auf 0 fest.
5. Berechnen Sie die Länge der Indexzeile:
Leaf_Row_Size = Fixed_Leaf_Size + Variable_Leaf_Size + Leaf_Null_Bitmap + 1 (für Zeilenüberschriftenaufwand einer Indexzeile) + 6 (für ID-Zeiger der untergeordneten Seite)
6. Berechnen Sie die Anzahl der Indexzeilen pro Seite (8096 freie Byte pro Seite):
Leaf_Rows_Per_Page = 8096 / (Leaf_Row_Size + 2)
Da sich eine Indexzeile nicht auf zwei Seiten erstreckt, muss die Anzahl der Indexzeilen pro Seite auf die nächste ganze Zeile abgerundet werden. Die Angabe 2 in der Formel bezieht sich auf den Eingang der Zeile in das Slotarray der Seite.
7. Berechnen Sie die Anzahl der reservierten freien Zeilen pro Seite anhand des angegebenen Füllfaktors:
Free_Rows_Per_Page = 8096 x ((100 - Fill_Factor) / 100) / (Leaf_Row_Size + 2)
Bei dem in der Berechnung verwendeten Füllfaktor handelt es sich nicht um einen Prozentwert, sondern um einen ganzzahligen Wert. Da sich eine Zeile nicht auf zwei Seiten erstreckt, muss die Anzahl der Zeilen pro Seite auf die nächste ganze Zeile abgerundet werden. Mit ansteigendem Füllfaktor werden mehr Daten auf jeder Seite gespeichert, und die Anzahl der Seiten nimmt ab. Die Angabe 2 in der Formel bezieht sich auf den Eingang der Zeile in das Slotarray der Seite.
8. Berechnen Sie die Anzahl der Seiten, die zum Speichern aller Zeilen benötigt werden:
Num_Leaf_Pages = Num_Rows / (Leaf_Rows_Per_Page - Free_Rows_Per_Page)
Die geschätzte Seitenanzahl muss auf die nächste ganze Seite aufgerundet werden.
9. Berechnen Sie die Größe des Indexes (insgesamt 8192 Byte pro Seite):
Leaf_Space_Used* = 8192 x *Num_Leaf_Pages
Schritt 3. Addieren der berechneten Werte
Addieren Sie die Werte, die in den beiden vorherigen Schritten abgerufen wurden:
Größe des nicht gruppierten Indexes (in Byte) = Leaf_Space_Used + Index_Space_used
In dieser Berechnung wird Folgendes nicht berücksichtigt:
- Partitionierung
Der Speicherplatzaufwand aus der Partitionierung ist geringfügig, seine Berechnung jedoch komplex. Er muss nicht berücksichtigt werden. - Zuordnungsseiten
Mindestens eine IAM-Seite wird zum Nachverfolgen der für einen Heap zugeordneten Seiten verwendet, der Speicherplatzaufwand ist jedoch nur minimal. Außerdem ist kein Algorithmus verfügbar, um deterministisch genau zu berechnen, wie viele IAM-Seiten verwendet werden. - LOB-Werte (Large Object)
Der Algorithmus zum Berechnen des genauen Speicherplatzes, der zum Speichern der Werte der LOB-Datentypen varchar(max), varbinary(max), nvarchar(max), text, ntext, xml und image erforderlich ist, ist komplex. Es ist ausreichend, einfach die durchschnittliche Größe der erwarteten LOB-Werte zu addieren, diese mit Num_Rows zu multiplizieren und das Ergebnis dann zur Gesamtgröße des nicht gruppierten Indexes zu addieren.
Siehe auch
Konzepte
Richtlinien für den Entwurf gruppierter Indizes
Erstellen von Indizes (Datenbankmodul)
Entwurfsrichtlinien für einen nicht gruppierten Index
Schätzen der Größe einer Tabelle
Schätzen der Größe eines gruppierten Indexes
Schätzen der Größe eines Heaps
Andere Ressourcen
Schätzen der Größe einer Datenbank