Version 5.6: Mehr Geschwindigkeit durch kleinere Datensätze

Für die Speicherung von Datensätzen mit Unicode-Zeichen verwendet die 5.6 ein modifiziertes Datensatzformat. Als zusätzliches Feature reduziert das neue Format den Speicherverbrauch durch das Eliminieren von leeren Feldern in gepackten Sätzen.


Mit Hilfe einer kleinen Bit-Tabelle pro Teildatensatz können leere Felder beim Packen des Satzes einfach weggelassen werden. Der Mehrverbrauch von einem Bit pro Feld wird durch die Einsparung von Leerwerten weit mehr als aufgewogen. Bei einem leeren Gleitkomma- oder Integer64-Feld werden 8 Bytes gespart, leere Integer32-, Datums- oder Zeitfelder sparen 4 Bytes ein. Logische Felder brauchen in Zukunft nur noch ein Bit (das direkt in der Bit-Tabelle steht) anstelle von einem Byte.

Angesichts von Terabyte-Festplatten stellt sich natürlich die Frage, wozu eine solche Sparmaßnahme eigentlich gut sein soll. Die Antwort heißt Performance. Ein limitierender Faktor der Verarbeitungsgeschwindigkeit ist die I/O-Leistung, beim typischen Betrieb einer oder mehrerer Datenbank auf einem Server kann dieser nur eine bestimmte Maximalzahl von I/O-Operationen pro Sekunde erreichen.

Die I/O-Operationen verwenden eine feste Blockgröße, wodurch sich eine bestimmte Menge von Datensätzen pro I/O ergibt. Schrumpft die durchschnittliche Datensatzgröße jetzt beispielsweise um 20%, steigt die Anzahl von Datensätzen pro I/O um 25%, der Server kann also mehr Datensätze pro Sekunde verarbeiten.

Die folgende Beispielprozedur speichert alle Datensätze einer Datenbank im neuen Format:

main
  LOCAL
  {
    tLoop     : int32;
    tFlags    : int32;
  }
{
  for tLoop # 1
  loop inc(tLoop)
  while (tLoop < 1000)
  {
    if (FileInfo(tLoop,_FileExists) > 0 and
        RecInfo(tLoop,_RecCount) > 0)
    {
      tFlags # _RecLock | _RecFirst;
      while (RecRead(tLoop,1,tFlags) < _rNoRec)
      {
        tFlags  # _RecLock | _RecNext;
        RecReplace(tLoop,_RecUnlock);
      }
    }
  }
}

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

4 Antworten

  1. Erst bei einer erweiteten Optimierung Schrumpft die Hauptanteil der Datenbank. Bei einem Test einer Live Datenbank von 21 GB ca. um 7 GB, Schrumpft diese auf 14 GB. Ohne Optimierung betrug diese erst ca. 650 MB

  2. @Andreas
    Das ist richtig, eine Konvertierung der Datensätze ist nicht notwendig, die Version 5.6 kann das bisherige Format auch entpacken.

  3. Wenn ich das richtig verstehe, findet keine automatische Konvertierung der Datensätze statt. Soll für bestehende Datensätze das neue Format verwendet werden, müssen diese gelesen und zurückgeschrieben werden.

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