Auf dieser Seite finden Sie einen Überblick über die spaltenbasierte Engine von AlloyDB for PostgreSQL und eine Anleitung zur Verwendung.
Die spaltenbasierte Engine von AlloyDB beschleunigt die Verarbeitung von Scans, Joins und Aggregaten in SQL-Abfrage durch die folgenden Komponenten:
Ein Spaltenspeicher, der Tabellendaten und Daten in der materialisierten Ansicht für ausgewählte Spalten enthält, die in einem spaltenorientierten Format neu organisiert wurden.
Ein spaltenorientierter Abfrageplaner und eine spaltenorientierte Ausführungs-Engine, die die Verwendung des Spaltenspeichers in Abfragen unterstützen.
Die spaltenbasierte Engine kann auf der primären Instanz, einer Lesepoolinstanz oder beiden verwendet werden. Sie können auch die automatische Spaltenformatierung verwenden, um Ihre Arbeitslast zu analysieren und den Spaltenspeicher automatisch mit den Spalten zu füllen, die die beste Leistungssteigerung bieten.
Wenn Sie die spaltenbasierte Engine für eine bestimmte Abfrage verwenden möchten, müssen alle Spalten in den Fragmenten dieser Abfrage, z. B. Joins und Scans, im Spaltenspeicher vorhanden sein.
Standardmäßig ist die spaltenbasierte Engine so konfiguriert, dass 30% des Arbeitsspeichers Ihrer Instanz verwendet werden. Je nach Arbeitslast, Arbeitsspeichernutzung und Konfiguration eines Lesepools können Sie die Arbeitsspeicherzuweisung für die spaltenbasierte Engine auf Ihrer primären Instanz reduzieren und der Lesepoolinstanz mehr Arbeitsspeicher zuweisen. Informationen zum Ansehen und Überwachen der Arbeitsspeichernutzung durch die spaltenbasierte Engine finden Sie unter Arbeitsspeichernutzung des Spaltenspeichers ansehen. Informationen zum Ändern der vom Spaltenspeicher verwendeten Speichergröße finden Sie unter Größe des Spaltenspeichers konfigurieren. Die empfohlene Arbeitsspeichergröße für die spaltenbasierte Engine für Ihre Instanz finden Sie unter Empfohlene Arbeitsspeichergröße für den Spaltenspeicher.
Abfragetypen, die von der spaltenbasierten Engine profitieren
Bestimmte Abfragen können von der spaltenbasierten Engine profitieren. Im Folgenden finden Sie eine Liste der Vorgänge und ihrer Abfragemuster, die am meisten von der spaltenbasierten Engine profitieren:
Table Scans
- Sie verfügt über selektive Filter wie
WHERE-Klauseln. - Sie verwendet eine kleine Anzahl von Spalten aus einer größeren Tabelle oder materialisierten Ansicht.
- Sie verwendet Ausdrücke wie
LIKE,SUBSTRoder „TRIM“.
- Sie verfügt über selektive Filter wie
Aggregatfunktionen
- Sie verwenden nur die folgenden Ausdrücke:
SUM,MIN,MAX,AVGundCOUNT. - Sie befinden sich am Anfang der Abfrage eines spaltenweisen Scans.
- Sie sind nicht gruppiert oder nach Spalten gruppiert.
- Sie verwenden nur die folgenden Ausdrücke:
ORDER-BYundSORT: nur, wenn sichORDER-BYoderSORTauf die Scanergebnisse von Spalten bezieht, auf die über die spaltenweise Engine zugegriffen wird.LIMIT: Nur wenn sich der Operator am Anfang der Abfrage eines spaltenweisen Scans und vor allenSORT- oderGROUP BY-Operatoren befindet.INNER HASH JOINnur, wenn die verwendeten Schlüssel Spalten sind und keine Join-Qualifizierer verwendet werden.Selektive Joins nur, wenn sich die Joins am Anfang der Abfrage eines spaltenweisen Scans befinden.
Weitere Informationen dazu, welche Abfragen am besten mit der spaltenbasierten Engine funktionieren, ob und wie die spaltenbasierte Engine von einer Abfrage verwendet wurde, finden Sie unter Verwendung der spaltenbasierten Engine mit EXPLAIN überprüfen.
Spaltenbasierte Engine verwenden
So verwenden Sie die spaltenbasierte Engine in einer AlloyDB-Instanz:
Aktivieren Sie die Engine auf der Instanz.
Das Aktivieren des Moduls ist ein einmaliger Vorgang, für den ein Neustart erforderlich ist.
Fügen Sie dem Spaltenspeicher Spalten hinzu.
Verwenden Sie eine der folgenden Methoden, um dem Spaltenspeicher Spalten hinzuzufügen:
Automatische Spaltenformatierung verwenden: Dabei wird Ihre Arbeitslast analysiert und automatisch Spalten hinzugefügt.
Spalten manuell hinzufügen: Sie können die Spalten basierend auf Ihrem Wissen über die Arbeitslast der Datenbanken in der Instanz hinzufügen.
Mit der Ansicht
g_columnar_relationskönnen Sie nachvollziehen, was im Spaltenspeicher enthalten ist. Nachdem Spalten hinzugefügt wurden, können Sie mit der AnweisungEXPLAINdie Verwendung der spaltenbasierten Engine in SQL-Abfragen prüfen.
Eine detaillierte Anleitung zur Verwendung der spaltenbasierten Engine finden Sie unter Spaltenbasierte Engine konfigurieren.
Welche Daten können dem Spaltenspeicher hinzugefügt werden?
Es gibt einige Einschränkungen hinsichtlich der Datentypen und Datenquellen, die Sie verwenden können, wenn Sie dem Spaltenspeicher Spalten hinzufügen.
Unterstützte Datentypen
Die spaltenbasierte Engine unterstützt nur Spalten mit den folgenden integrierten Datentypen:
arraybigintbooleanbyteachardatedecimaldouble precisionenumfloat4float8integerjsonjsonbnumericrealserialshortsmallinttexttimestamptimestamptzuuidvarcharvector
Die spaltenbasierte Engine ignoriert alle Versuche, dem Spaltenspeicher manuell Spalten mit nicht unterstützten Datentypen hinzuzufügen.
Nicht unterstützte Datenquellen
Die spaltenbasierte Engine unterstützt keine Tabellen oder materialisierten Ansichten mit den folgenden Attributen als Datenquellen:
Nicht-Blatt-partitionierte Tabellen
Fremde Tabellen
Einschränkungen der spaltenbasierten Engine
- Wenn Sie eine Analyseabfrage für eine Spalte mit einem Index ausführen, kann der AlloyDB-Optimierer den Zeilenspeicher verwenden.
- Spalten, die dem Spaltenspeicher manuell hinzugefügt wurden, werden nicht automatisch entfernt. Wenn Sie manuell hinzugefügte Spalten erzwingen möchten, verwenden Sie
google_columnar_engine_drop()in Ihrer Instanz. - Bei der automatischen Spaltenorientierung werden Spalten möglicherweise dynamisch hinzugefügt und entfernt, je nachdem, wie sie in Abfragen verwendet werden.
- Nicht alle Datentypen werden von der spaltenbasierten Engine unterstützt. Weitere Informationen finden Sie unter Unterstützte Datentypen.
Häufige Aktualisierungen von Zeilen machen Spaltendaten ungültig. Wenn Sie eine Tabelle oder eine materialisierte Ansicht im Spaltenspeicher validieren möchten, können Sie entweder die Aktualisierungshäufigkeit verringern oder die Aktualisierungen der spaltenbasierten Engine häufiger planen.
Sie können die Spalten
invalid_block_countundtotal_block_countin g_columnar_relations vergleichen, um zu prüfen, ob Ihre Tabelle oder Ansicht betroffen ist. Wenn sich Ihre Tabelle oder Ansicht häufig oder in großem Umfang ändert, ist derinvalid_block_counthoch.Eine partitionierte Tabelle kann nicht direkt in die Spalten-Engine eingefügt werden. Wenn Sie die spaltenbasierte Engine verwenden möchten, müssen Sie jede der Blattpartitionen der Tabelle einzeln füllen.
Bei Tabellen oder Ansichten mit einer geringen Anzahl von Zeilen (in der Regel weniger als 5.000) kann der Abfrageplaner den Zeilenspeicher anstelle des Spaltenspeichers verwenden, um die Leistung zu verbessern, auch wenn die Daten erfolgreich in die spaltenorientierte Engine geladen wurden.