Die Schlüssel-Reorganisation im Detail

Nach dem Anlegen eines neuen Schlüssels oder der Änderung eines bestehenden Schlüssels (Attribute oder Schlüsselfelder) ist ein Neuaufbau des Index notwendig – heute wollen wir diesen als Reorganisation bezeichneten Vorgang näher betrachten, der im übrigen komplett vom Datenbankserver ausgeführt wird.


Bei einer Veränderung eines Schlüssels muss vor der Generierung der neuen Schlüsselwerte zunächst das Löschen des bisherigen Index erfolgen. Dabei werden in der Datenbank zuerst die Wurzel und die Knotensegmente der Baumstruktur gelesen und gelöscht. Bei dieser Operation entstehen zwar Random-Zugriffe in die Datenbank, jedoch werden weniger als 1% des Index auf diese Weise verarbeitet. Beim Lesen dieser Segmente wird ein Verzeichnis aller Blattsegmente erstellt – diese enthalten die eigentlichen Schlüsselwerte und machen über 99% des Index aus. Alle Blattsegmente werden anschließend sortiert und in der Reihenfolge ihrer Segmentnummern gelesen und gelöscht. Dadurch besteht dieser Vorgang zum größten Teil aus sequentiellen Datenbankzugriffen und ermöglicht eine wesentliche höhere Löschgeschwindigkeit. Insbesondere bei Tabellen mit vielen Datensätzen und langen Schlüsselwerten kann der Löschvorgang trotzdem mehrere Minuten dauern. In dieser Zeit bleibt die Anzeige des Reorganisationsfortschritts unverändert.

Für die nachfolgende Generierung der neuen Schlüsselwerte benutzt der Datenbankserver zwei verschiedene Strategien. Bei weniger als 1000 Datensätzen wird ein weiterer Thread im Datenbankprozess gestartet, der diese Aufgabe übernimmt. Dabei werden nacheinander alle Datensätze der Tabelle in der Reihenfolge ihrer RecIDs gelesen und entpackt. Für jeden Datensatz wird der neue Schlüsselwert generiert und in den Indexbaum eingefügt. Der laufende Benutzerthread erledigt die Kommunikation mit dem Client, um die Anzeige des Fortschritts und einen eventuellen Abbruch der Reorganisation zu ermöglichen.

Diese Strategie erzeugt bei sehr großen Tabellen mit mehreren Millionen Datensätzen eine hohe I/O-Last, die fast ausschließlich aus Random-Zugriffen besteht. Dementsprechend lange würde ein Reorganisationslauf dauern. Enthält die Tabelle mehr als 1000 Sätze, wählt der Server daher eine aufwendigere Verarbeitung.

Der erste Schritt besteht aus dem Anlegen eines Segmentverzeichnis für alle Datensätze der Tabelle. Mit Hilfe dieses Verzeichnis kann dann ein eigener Thread alle Datensätze der Tabelle in aufsteigender Segmentreihenfolge lesen. Hierbei finden überwiegend sequentielle Zugriffe statt. Für jeden gelesenen Satz generiert der Thread den neuen Schlüsselwert und legt ihn in einem Puffer im Hauptspeicher ab. Ein weiterer Thread liest die Schlüsselwerte aus diesem Puffer und fügt sie in den Indexbaum ein. Diese Aufgabenteilung erhöht ebenfalls die Reorganisationgeschwindigkeit.

Die wichtigste Voraussetzung für eine schnelle Reorganisation ist jedoch eine ausreichende Menge an Datenbankpuffer. Reicht der Cache nicht für den gesamten Indexbaum aus, bricht die Geschwindigkeit mit zunehmender Dauer ein, der Lauf wird sichtbar immer langsamer. Vor größeren Reorganisationen sollten die Einstellungen daher auf eine ausreichende Cachegröße hin überprüft werden.

Beim Neuaufbau mehrerer Schlüssel einer Tabelle, werden diese nacheinander generiert. Falls alle Datensätze der Tabelle in den Datenbankpuffer passen, reduziert das die Dauer für den zweiten und alle weiteren Schlüssel.

Klicken Sie hier, um die Nutzungsbedingungen für unseren Blog zu lesen.

2 Antworten

  1. Ja, das geht so ähnlich: (Schlüssellänge in Bytes + 9) * Anzahl Datensätze * 1,3 ergibt ungefähr den notwendigen Puffer für den Index.

Schreiben Sie einen Kommentar

Ihre E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert

Leave the field below empty!

Wünsche, Fragen oder Feedback sind willkommen:

Nutzungsbedingungen der Kommentarfunktion im Blog

1. Allgemeines

Vectorsoft AG („Anbieter“) stellt für Internetnutzer („Nutzer“) auf der Website
vectorsoft.de einen öffentlichen Blog bereit. Der öffentliche Blog dient dem
Informations- und Gedankenaustausch. Die Nutzer, welche sich mit Beiträgen und
Kommentaren beteiligen, verpflichten sich dazu, die Blog-Nutzungsbedingungen
einzuhalten und tragen die Verantwortung für die Richtigkeit und Angemessenheit
sowie Freiheit von Rechtsverletzungen ihrer Beiträge. Mit Nutzung der
Kommentarfunktion in unserem Blog akzeptieren Sie diese Nutzungsbedingungen.

2. Netiquette

Wir bitten Sie von persönlichen Angriffen und Provokationen aufgrund anderer
Meinungen abzusehen. Bitte argumentieren Sie sachlich und bewegen Sie sich auf
der Basis einer konstruktiven Diskussionskultur. Ihr Kommentar sollte stets im
Zusammenhang mit dem jeweiligen Thema sein, um Ausschweifungen in andere
Themenbereiche zu vermeiden. Das mehrmalige Posten desselben Kommentars
oder mehrerer ähnlicher Kommentare ist nicht erlaubt.

3. Verbot rechtswidriger Inhalte

Mit Absenden Ihres Kommentars bestätigen Sie, dass Sie keine Urheberrechte oder andere Rechte Dritter verletzen. Volksverhetzende, rassistische Äußerungen, Anleitungen zu Straftaten und deren Verherrlichung, Gewaltdarstellungen, pornografische Inhalte und Äußerungen, die Persönlichkeitsrechte verletzen sind untersagt.

4. Keine Werbung

Die Nutzung der Kommentarfunktion ist für kommerzielle oder parteipolitische
Zwecke nicht erlaubt. Werbliche Beiträge aller Art werden von uns umgehend
gelöscht.

5. Angaben zum Namen

Bei der Eingabe Ihres Namens achten Sie auf die zuvor genannten Grundsätze.

6. Quellenangaben

Bitte geben Sie bei der beabsichtigten Veröffentlichung von Zitaten oder Beiträgen
Dritter die jeweiligen Quellen an und erläutern dessen Bezug zum Blogbeitrag.

7. Verstoß gegen die Nutzungsbedingungen

Beiträge, die gegen diese Richtlinie verstoßen werden umgehend gelöscht. Sollten
Sie selbst Verstöße bemerken, so senden Sie uns bitte den Link des betreffenden
Kommentars per E-Mail an . Wir weisen ausdrücklich daraufhin, dass wir einzelne Nutzer bei wiederholten oder schweren Verstößen gegen diese
Nutzungsbedingungen ausschließen werden.

Stand: Sept. 2024

Deine Trial Version - jetzt anfordern!

Teste yeet - unverbindlich und kostenfrei

IHRE EVALUIERUNGSLIZENZ - JETZT ANFORDERN!

TESTEN SIE DIE CONZEPT 16 VOLLVERSION - UNVERBINDLICH und KOSTENFREI

Melden Sie sich bei unserem Newsletter an

Anrede*
     
Zustimmung zur Datenverarbeitung gem. DSGVO*



WordPress Cookie-Hinweis von Real Cookie Banner