ALTER TABLE
説明
既存のテーブルを変更します。以下を含みます:
- テーブル、パーティション、インデックス、または列の名前変更
- テーブルコメントの変更
- パーティションの変更(パーティションの追加/削除とパーティション属性の変更)
- バケット法とバケット数の変更
- 列の変更(列の追加/削除、列順の変更、列コメントの変更)
- ロールアップインデックスの作成/削除
- ビットマップインデックスの変更
- テーブルプロパティの変更
- アトミックスワップ
- 手動データバージョンコンパクション
- 主キー永続インデックスの削除
ヒント
この操作には、対象テーブルに対するALTER権限が必要です。
構文
ALTER TABLE [<db_name>.]<tbl_name>
alter_clause1[, alter_clause2, ...]
alter_clause には次の操作を含めることができます:名前変更、コメント、パーティション、バケット、列、ロールアップインデックス、ビットマップインデックス、テーブルプロパティ、スワップ、コンパクション。
- 名前変更: テーブル、ロールアップインデックス、パーティション、または列の名前を変更します(v3.3.2以降でサポート)。
- コメント: テーブルコメントを変更します(v3.1以降でサポート)。
- パーティション: パーティションプロパティを変更し、パーティションを削除または追加します。
- バケット: バケット法とバケット数を変更します。
- 列: 列の追加、削除、並び替え、列のタイプの変更、コメントの変更
- ロールアップインデックス: ロールアップインデックスを作成または削除します。
- ビットマップインデックス: インデックスを変更します(ビットマップインデックスのみ変更可能)。
- スワップ: 2つのテーブルをアトミックに交換します。
- コンパクション: ロードされたデータのバージョンをマ ージするために手動でコンパクションを実行します(v3.1以降でサポート)。
- 永続インデックスの削除: 共有データクラスタの主キーテーブルの永続インデックスを削除します (v3.3.9以降でサポートされています)。
制限と使用上の注意
- パーティション、列、ロールアップインデックスに対する操作は、1つのALTER TABLE文で実行できません。
- 1つのテーブルには、同時に1つのスキーマ変更操作しか行えません。同時に2つのスキーマ変更コマンドを実行することはできません。
- バケット、列、ロールアップインデックスに対する操作は非同期操作です。タスクが送信されるとすぐに成功メッセージが返されます。進行状況を確認するには SHOW ALTER TABLE コマンドを実行し、操作をキャンセルするには CANCEL ALTER TABLE コマンドを実行できます。
- 名前変更、コメント、パーティション、ビットマップインデックス、スワップに対する操作は同期操作であり、コマンドの返り値は実行が完了したことを示します。