ALTER TABLE ROLLUP
説明
このステートメントは、既存のテーブルに対してrollup変更操作を実行するために使用されます。rollupは非同期操作であり、タスクが正常に送信されるとタスクが返されます。その後、SHOW ALTERコマンドを使用して進行状況を確認できます。
文法:
ALTER TABLE [database.]table alter_clause;
rollupのalter_clauseは以下の作成方法をサポートしています
- rollupインデックスの作成
文法:
ADD ROLLUP rollup_name (column_name1, column_name2, ...)
[FROM from_index_name]
[PROPERTIES ("key"="value", ...)]
properties: タイムアウト時間の設定をサポートし、デフォルトのタイムアウト時間は1日です。
- rollupインデックスをバッチで作成
grammar:
ADD ROLLUP [rollup_name (column_name1, column_name2, ...)
[FROM from_index_name]
[PROPERTIES ("key"="value", ...)],...]
注意事項:
- from_index_nameが指定されていない場合、デフォルトでベースインデックスから作成されます
- ロールアップテーブルの列は、from_index内に既に存在する列である必要があります
- propertiesでは、ストレージ形式を指定できます。詳細については、CREATE TABLEを参照してください
- ロールアップインデックスの削除
文法:
DROP ROLLUP rollup_name [PROPERTIES ("key"="value", ...)]
- ロールアップインデックスのバッチ削除
文法:
DROP ROLLUP [rollup_name [PROPERTIES ("key"="value", ...)],...]
注意:
- base indexは削除できません
Examples
- indexを作成:example_rollup_index、base index (k1,k2,k3,v1,v2)に基づく。列指向ストレージ。
ALTER TABLE example_db.my_table
ADD ROLLUP example_rollup_index(k1, k3, v1, v2);
- インデックスを作成: example_rollup_index2、example_rollup_index (k1,k3,v1,v2) をベースとする
ALTER TABLE example_db.my_table
ADD ROLLUP example_rollup_index2 (k1, v1)
FROM example_rollup_index;
- インデックスを作成: example_rollup_index3、ベースインデックス(k1,k2,k3,v1)に基づき、カスタムrollupタイムアウトを1時間に設定。
ALTER TABLE example_db.my_table
ADD ROLLUP example_rollup_index(k1, k3, v1)
PROPERTIES("timeout" = "3600");
- インデックスを削除: example_rollup_index2
ALTER TABLE example_db.my_table
DROP ROLLUP example_rollup_index2;
- ロールアップインデックスの一括削除
ALTER TABLE example_db.my_table
DROP ROLLUP example_rollup_index2,example_rollup_index3;
- キーワード
ALTER, TABLE, ROLLUP, ALTER TABLE