ALTER TABLE PROPERTY
パーティション AttributesとTable Attributesの違い
- パーティション attributesは一般的にbuckets数(buckets)、ストレージメディア(storage_medium)、レプリケーション数(replication_num)、およびホット/コールドデータ分離ポリシー(storage_policy)に焦点を当てます。
- 既存のpartitionについては、ALTER TABLE {tableName} MODIFY PARTITION ({partitionName}) SET ({key}={value})を使用して変更できますが、buckets数(buckets)は変更できません。
- 未作成のdynamic partitionsについては、ALTER TABLE {tableName} SET (dynamic_partition.{key} = {value})を使用してattributesを変更できます。
- 未作成のauto partitionsについては、ALTER TABLE {tableName} SET ({key} = {value})を使用してattributesを変更できます。
- ユーザーがpartition attributesを変更したい場合、既に作成されたpartitionsのattributesと、未作成のpartitionsのattributesの両方を変更する必要があります。
- 上記のattributes以外は、すべてtableレベルです。
- 具体的なattributesについては、create table attributesを参照してください
説明
このステートメントは、既存のTableのプロパティを変更するために使用されます。この操作は同期的であり、コマンドの戻りは実行の完了を示します。
Tableのプロパティを変更します。現在、bloom filterカラム、colocate_with attribute、dynamic_partition attribute、replication_numおよびdefault.replication_numの変更をサポートしています。
構文:
ALTER TABLE [database.]table alter_clause;
alter_clause of propertyは以下の変更方法をサポートしています。
注意:
上記のスキーマ変更操作にマージして変更することも可能です。以下の例を参照してください。
- Tableのbloom filterカラムを変更する
ALTER TABLE example_db.my_table SET ("bloom_filter_columns"="k1,k2,k3");
上記のスキーマ変更操作に組み込むこともできます(複数の句の構文が若干異なることに注意してください)
ALTER TABLE example_db.my_table
DROP COLUMN col2
PROPERTIES ("bloom_filter_columns"="k1,k2,k3");
- TableのColocateプロパティを変更する
ALTER TABLE example_db.my_table set ("colocate_with" = "t1");
- Tableのバケッティング手法をHash DistributionからRandom Distributionに変更する
ALTER TABLE example_db.my_table set ("distribution_type" = "random");
- Tableの動的パーティション属性を変更する(動的パーティション属性を持たないTableに動的パーティション属性を追加することをサポート)
ALTER TABLE example_db.my_table set ("dynamic_partition.enable" = "false");
動的パーティション属性を持たないTableに動的パーティション属性を追加する必要がある場合は、すべての動的パーティション属性を指定する必要があります (注意: 非パーティションTableに対する動的パーティション属性の追加はサポートされていません)
ALTER TABLE example_db.my_table set (
"dynamic_partition.enable" = "true",
"dynamic_partition.time_unit" = "DAY",
"dynamic_partition.end" = "3",
"dynamic_partition.prefix" = "p",
"dynamic_partition. buckets" = "32"
);
- Tableのin_memory属性を変更します。値は'false'のみ設定可能です
ALTER TABLE example_db.my_table set ("in_memory" = "false");
- バッチ削除機能を有効にする
ALTER TABLE example_db.my_table ENABLE FEATURE "BATCH_DELETE";
注意:
- ユニークTableのみサポート
- 古いTableではバッチ削除がサポートされ、新しいTableでは作成時に既にサポートされている
- sequenceカラムの値に従ってインポート順序を保証する機能を有効化
ALTER TABLE example_db.my_table ENABLE FEATURE "SEQUENCE_LOAD" WITH PROPERTIES (
"function_column.sequence_type" = "Date"
);
注意:
- ユニークTableのみサポート
- sequence_typeはシーケンスカラムの型を指定するために使用され、integral型とtime型を指定可能
- 新たにインポートされるデータの順序性のみサポート。履歴データは変更不可
- Tableのデフォルトbucket数を50に変更
ALTER TABLE example_db.my_table MODIFY DISTRIBUTION DISTRIBUTED BY HASH(k1) BUCKETS 50;
注意:
- RANGE パーティションと HASH ディストリビューションを持つ非配置Tableのみサポート
- Tableコメントの変更
ALTER TABLE example_db.my_table MODIFY COMMENT "new comment";
- カラムコメントの変更
ALTER TABLE example_db.my_table MODIFY COLUMN k1 COMMENT "k1", MODIFY COLUMN k2 COMMENT "k2";
- エンジンタイプを変更する
MySQLタイプのみをODBCタイプに変更できます。driverの値は、odbc.init設定内のドライバー名です。
ALTER TABLE example_db.mysql_table MODIFY ENGINE TO odbc PROPERTIES("driver" = "MySQL");
- コピー数の変更
ALTER TABLE example_db.mysql_table SET ("replication_num" = "2");
ALTER TABLE example_db.mysql_table SET ("default.replication_num" = "2");
ALTER TABLE example_db.mysql_table SET ("replication_allocation" = "tag.location.default: 1");
ALTER TABLE example_db.mysql_table SET ("default.replication_allocation" = "tag.location.default: 1");
注意:
- defaultプレフィックス付きのプロパティは、変更されたTableのデフォルトレプリカ分散を示します。この変更は、Tableの現在の実際のレプリカ分散を変更せず、パーティション化されたTableの新しく作成されたパーティションのレプリカ分散にのみ影響します。
- パーティション化されていないTableの場合、defaultプレフィックスなしでレプリカ分散プロパティを変更すると、Tableのデフォルトレプリカ分散と実際のレプリカ分散の両方が変更されます。つまり、変更後、
show create tableおよびshow partitions from tblステートメントを通じて、レプリカ分散が変更されたことを確認できます。 - パーティション化されたTableの場合、Tableの実際のレプリカ分散はパーティションレベルにあります。つまり、各パーティションは独自のレプリカ分散を持ち、これは
show partitions from tblステートメントを通じて表示できます。実際のレプリカ分散を変更したい場合は、ALTER TABLE PARTITIONを参照してください。
13. [実験的] light_schema_changeを有効にする
light_schema_changeを有効にして作成されていないTableの場合、以下のステートメントを使用して有効にすることができます。
ALTER TABLE example_db.mysql_table SET ("light_schema_change" = "true");
例
- Tableのbloom filterカラムを変更する
ALTER TABLE example_db.my_table SET ("bloom_filter_columns"="k1,k2,k3");
上記のスキーマ変更操作にも組み込むことができます(複数の句の構文が若干異なることに注意してください)
ALTER TABLE example_db.my_table
DROP COLUMN col2
PROPERTIES ("bloom_filter_columns"="k1,k2,k3");
- TableのColocateプロパティを変更する
ALTER TABLE example_db.my_table set ("colocate_with" = "t1");
- Tableのバケット化方法をHash DistributionからRandom Distributionに変更する
ALTER TABLE example_db.my_table set ("distribution_type" = "random");
- Tableの動的パーティション属性を変更する(動的パーティション属性を持たないTableに動的パーティション属性を追加することをサポート)
ALTER TABLE example_db.my_table set ("dynamic_partition.enable" = "false");
動的パーティション属性を持たないTableに動的パーティション属性を追加する必要がある場合は、すべての動的パーティション属性を指定する必要があります (注意:非パーティションTableでは動的パーティション属性の追加はサポートされていません)
ALTER TABLE example_db.my_table set ("dynamic_partition.enable" = "true", "dynamic_partition.time_unit" = "DAY", "dynamic_partition.end" = "3", "dynamic_partition.prefix" = "p", "dynamic_partition. buckets" = "32");
- Tableのin_memory属性を変更します。値は'false'のみ設定可能です
ALTER TABLE example_db.my_table set ("in_memory" = "false");
- バッチ削除機能を有効にする
ALTER TABLE example_db.my_table ENABLE FEATURE "BATCH_DELETE";
- sequence列の値に従ってインポート順序を保証する機能を有効にする
ALTER TABLE example_db.my_table ENABLE FEATURE "SEQUENCE_LOAD" WITH PROPERTIES ("function_column.sequence_type" = "Date");
- Tableのデフォルトのbucket数を50に変更する
ALTER TABLE example_db.my_table MODIFY DISTRIBUTION DISTRIBUTED BY HASH(k1) BUCKETS 50;
- Tableコメントの変更
ALTER TABLE example_db.my_table MODIFY COMMENT "new comment";
- カラムコメントを変更する
ALTER TABLE example_db.my_table MODIFY COLUMN k1 COMMENT "k1", MODIFY COLUMN k2 COMMENT "k2";
- エンジンタイプを変更する
ALTER TABLE example_db.mysql_table MODIFY ENGINE TO odbc PROPERTIES("driver" = "MySQL");
- Tableにコールドおよびホット分離データ移行戦略を追加する
ALTER TABLE create_table_not_have_policy set ("storage_policy" = "created_create_table_alter_policy");
注意:Tableは、ストレージポリシーに関連付けられていない場合にのみ正常に追加できます。Tableは1つのストレージポリシーのみを持つことができます。
- Tableのパーティションにホットデータとコールドデータの移行戦略を追加する
ALTER TABLE create_table_partition MODIFY PARTITION (*) SET("storage_policy"="created_create_table_partition_alter_policy");
注意: Tableのパーティションは、ストレージポリシーに関連付けられていない場合にのみ正常に追加できます。Tableは1つのストレージポリシーのみを持つことができます。
Keywords
ALTER, TABLE, PROPERTY, ALTER TABLE