您可以根據工作負載,手動將資料欄新增至資料欄存放區,或從資料欄存放區捨棄資料表或具體化檢視表的部分或所有資料欄。查詢評估作業會自動使用儲存的資料欄資料來回答查詢。
選擇要新增至資料欄存放區的資料表、具體化檢視區塊和資料欄時,請同時考量資料欄存放區的大小和工作負載的形狀。適合選取的項目包括經常掃描的大型資料表或檢視區塊。在這些資料表或檢視區塊中,找出 OLAP 工作負載使用的任何大型非專屬索引。您可以將這些索引的資料欄新增至資料欄存放區,並可能捨棄索引,進而消除與主要執行個體維護相關的效能成本。
如要管理資料欄引擎資料欄儲存區的內容,請使用下列其中一種方法:
如要瞭解在資料欄儲存區中新增表格、資料欄和具體化檢視區時,可使用的資料類型和資料來源,請參閱「可新增至資料欄儲存區的資料」。
更新資料庫旗標,管理資料欄儲存內容
您可以更新 google_columnar_engine.relations
資料庫標記,手動管理資料欄儲存內容。這個旗標只有一個值,可指定所有資料欄商店的資料來源。重新啟動期間,系統會自動將這個標記中指定的資料欄填入資料欄存放區。
您可以搭配自動欄狀化使用這個標記。如果資料欄引擎在透過 google_columnar_engine.relations
標記填入您指定的資料欄後,仍有可用記憶體,自動資料欄化功能就會視需要將更多資料欄新增至資料欄存放區。
使用標記新增資料欄
如要將資料欄新增至資料欄存放區,請定義執行個體的 google_columnar_engine.relations
標記。將值設為以半形逗號分隔的項目清單,每個項目指定要從特定資料表納入的資料欄清單,格式如下:
DATABASE_NAME.SCHEMA_NAME.TABLE_NAME(COLUMN_LIST)
更改下列內容:
DATABASE_NAME:包含要新增至資料欄存放區的資料欄的資料庫。
SCHEMA_NAME:識別要新增至資料欄存放區的資料表或具體化檢視區塊的結構定義,例如
public
。TABLE_NAME:包含要新增至資料欄存放區的資料欄的資料表或具體化檢視區塊。
COLUMN_LIST:以逗號分隔的清單,當中列有要新增至資料欄存放區的資料欄。
如要新增資料表或具體化檢視表的所有資料欄,請省略資料欄清單:
DATABASE_NAME.SCHEMA_NAME.TABLE_NAME
ALTER SYSTEM SET google_columnar_engine.relations='DATABASE_NAME.SCHEMA_NAME.TABLE_NAME(COLUMN_1,COLUMN_2)';
使用標記捨棄資料欄
如要從資料欄存放區捨棄資料欄,請為google_columnar_engine.relations
標記設定新值 (如「使用標記新增資料欄」所述),並省略要捨棄的資料欄。
如要從資料欄商店捨棄所有資料欄,請從執行個體取消設定 google_columnar_engine.relations
旗標。
如要進一步瞭解如何在執行個體上設定資料庫標記,請參閱「設定 AlloyDB Omni 資料庫參數」。
使用 SQL 函式管理資料欄儲存區內容
您可以使用 SQL 函式手動管理資料欄儲存區內容。
使用 SQL 函式新增資料欄
執行 google_columnar_engine_add
SQL 函式,將資料欄新增至資料欄存放區。
這個方法會將指定資料欄新增至資料欄存放區,並只管理連結節點中的資料欄。重新啟動執行個體後,商店不會保留新欄位。
這個方法不會變更資料庫標記 google_columnar_engine.relations
。自動欄狀化不會考量這個 SQL 函式新增的資料欄。
psql 用戶端
SELECT google_columnar_engine_add( relation => 'TABLE_NAME', columns => 'COLUMN_LIST' );
-
取代下列項目:
- 「TABLE_NAME」:包含資料表或具體化檢視表名稱的字串。如果資料表或檢視區塊位於
public
以外的結構定義中,請指定結構定義名稱、半形句號,以及資料表或檢視區塊的名稱,例如'myschema.mytable'
。 - 「COLUMN_LIST」:字串,內含以半形逗號分隔的清單,列出要新增的資料欄名稱 (區分大小寫)。如要將資料表或具體化檢視區塊的所有資料欄新增至資料欄存放區,請省略這個參數。
使用 SQL 函式捨棄資料欄
執行 google_columnar_engine_drop
SQL 函式,如下所示:
psql 用戶端
SELECT google_columnar_engine_drop( relation => 'TABLE_NAME', columns => 'COLUMN_LIST' );
- 「TABLE_NAME」:包含資料表或具體化檢視表名稱的字串。如果資料表或檢視區塊位於
public
以外的結構定義中,請指定結構定義名稱、半形句號,以及資料表或檢視區塊的名稱,例如'myschema.mytable'
。 - 「COLUMN_LIST」:字串,內含以半形逗號分隔的清單,列出要新增的資料欄名稱 (區分大小寫)。如要將資料表或具體化檢視區塊的所有資料欄新增至資料欄存放區,請省略這個參數。
您可以使用 google_columnar_engine_drop
函式移除透過編輯 google_columnar_engine.relations
資料庫標記新增的資料欄。不過,這麼做的話,當執行個體重新啟動時,這些資料欄會重新新增至資料欄式儲存空間。