AlloyDB Omni 資料欄引擎提供下列元件,可加快掃描、聯結和匯總的 SQL 查詢處理速度:
資料欄儲存區,內含所選資料欄的資料表和具體化檢視資料,並以資料欄導向格式重新整理。
資料欄查詢規劃工具和執行引擎,支援在查詢中使用資料欄儲存空間。
您可以在主要執行個體、讀取集區執行個體或兩者上使用資料欄引擎。 您也可以使用自動欄狀化功能分析工作負載,並自動在資料欄存放區中填入可提供最佳效能增益的資料欄。
如要搭配特定查詢使用直欄引擎,查詢中參照的所有資料欄 (例如聯結、掃描) 都必須位於直欄存放區。
根據預設,直欄引擎會使用執行個體 1 GB 的記憶體。視工作負載、記憶體用量,以及是否已設定讀取集區而定,您可以選擇減少主要執行個體上的資料欄引擎記憶體配置,並將更多記憶體配置給讀取集區執行個體。
如要查看及監控直欄引擎的記憶體用量,請參閱「查看直欄儲存空間記憶體用量」。如要修改資料欄商店使用的記憶體大小,請參閱「設定資料欄商店的大小」。如要找出執行個體適用的建議資料欄引擎記憶體大小,請參閱「建議資料欄存放區記憶體大小」。
可透過資料欄引擎提升效率的查詢類型
某些查詢可透過資料欄引擎提升效能。以下列出最適合使用資料欄引擎的作業和查詢模式:
作業 | 查詢模式 |
---|---|
資料表掃描 | 選擇性篩選器,例如WHERE 子句。大型資料表或具體化檢視區塊中的少量資料欄。 例如 LIKE 、SUBSTR 或 TRIM 等運算式。 |
匯總函式 | 僅限 SUM 、MIN 、MAX 、AVG 和 COUNT 等運算式。在資料欄掃描查詢開始時。 未分組或按欄分組。 |
ORDER-BY |
只有在直欄掃描的查詢開頭使用運算子時,才需要這麼做。 |
SORT |
只有在運算子位於資料行掃描的查詢開頭,且只依資料表或具體化檢視表的基底資料欄排序時,才會發生這種情況。 |
LIMIT |
只有在運算子位於資料欄掃描的查詢開頭,且位於任何 SORT 或 GROUP BY 運算子之前,才適用這項規則。 |
INNER HASH JOIN |
只有在使用的鍵是資料欄,且未使用任何聯結限定詞時,才需要這麼做。 |
選擇性彙整 | 只有在資料行掃描查詢的開頭加入時。 |
如要進一步瞭解哪些查詢最適合使用資料欄引擎、查詢是否使用資料欄引擎,以及使用方式,請參閱「使用 EXPLAIN
驗證資料欄引擎的使用情形」。
如何在 AlloyDB Omni 執行個體中使用資料欄引擎
如要在 AlloyDB Omni 執行個體中使用資料欄引擎,請執行下列高階步驟:
在執行個體上啟用引擎。
啟用引擎為一次性作業,需要重新啟動資料庫。
將資料欄新增至資料欄商店。
如要將資料欄新增至資料欄存放區,請使用下列其中一種方法:
您可以使用
g_columnar_relations
檢視畫面追蹤資料欄商店中的內容,並在新增資料欄後,使用EXPLAIN
陳述式驗證 SQL 查詢中資料欄引擎的使用情形。
如需有關如何使用資料欄引擎的詳細操作說明,請參閱「設定資料欄引擎」。
可新增至資料欄儲存空間的資料
將資料欄新增至資料欄存放區時,可使用的資料類型和資料來源會受到限制。
支援的資料類型
直欄引擎僅支援具有下列內建資料類型的直欄:
array
bigint
boolean
bytea
char
date
decimal
double precision
enum
float4
float8
integer
json
jsonb
numeric
real
serial
short
smallint
text
timestamp
uuid
varchar
如果嘗試手動將含有不支援資料類型的資料欄新增至資料欄存放區,資料欄引擎會忽略這類要求。
不支援的資料來源
直欄引擎不支援以具有下列屬性的資料表或具體化檢視表做為資料來源:
非葉節點分區資料表
外部資料表
列數少於 5,000 列的資料表或檢視畫面
資料欄引擎限制
- 如果您對有索引的資料欄執行分析查詢,AlloyDB Omni 最佳化工具可能會選擇使用列儲存區。
- 手動新增至資料欄商店的資料欄不會自動移除。如要強制移除手動新增的資料欄,請在執行個體上使用
google_columnar_engine_drop
。 - 自動直欄化功能可能會根據查詢用量動態新增及移除資料欄。
- 資料欄引擎不支援所有資料類型。如要查看支援的資料類型,請參閱「支援的資料類型」。
如果經常更新資料列,欄狀資料就會失效。如要驗證資料欄存放區中的資料表或具體化檢視區塊,您可以降低更新頻率,或更頻繁地排定資料欄引擎重新整理作業。
您可以比較「
invalid_block_count
」和「total_block_count
」欄,g_columnar_relations
確認表格或檢視畫面是否受到影響。如果表格或檢視畫面經常或大量變更,invalid_block_count
就會偏高。