OceanBaseデータベースでは、DYNAMIC_PARTITION_POLICY ブロックを使用して、テーブル作成時にその動的パーティション管理属性を指定します。
本記事では、SQLステートメントを使用して動的パーティションテーブルを作成する方法について説明します。
使用上の制限と注意事項
現在のバージョンでは、動的パーティションテーブルを作成するには、少なくとも1つのパーティション定義を指定する必要があります。
Range ColumnsパーティションとRangeパーティションのみサポートしています:
- Range Columnsパーティション:パーティションキーが
date、datetime、timestamp、year、bigint(BIGINT_PRECISION精度を指定)型のパーティションテーブルで動的パーティション管理を有効にできます。 - Rangeパーティション:パーティションキーが
year、bigint(BIGINT_PRECISION精度を指定)型のパーティションテーブルで動的パーティション管理を有効にできます。
- Range Columnsパーティション:パーティションキーが
動的パーティション管理は、パーティションテーブルおよびサブパーティションテーブルのパーティションに対してのみ有効です。
テーブル作成後の事前作成パーティションの作成および期限切れパーティションの削除は即時には実行されません。次回の動的パーティション管理タスクの自動スケジュールまたは手動でのスケジュールが必要です。動的パーティション管理タスクのスケジュールに関する詳細は、動的パーティション管理タスクを参照してください。
権限要件
動的パーティションテーブルを作成するには、CREATE 権限が必要です。OceanBaseデータベースの権限の詳細については、MySQLモードの権限分類を参照してください。
構文
動的パーティションテーブルを作成するSQLステートメントの形式は次のとおりです:
CREATE TABLE [IF NOT EXISTS] table_name (table_definition_list)
DYNAMIC_PARTITION_POLICY [=] (dynamic_partition_policy_list)
partition_option;
dynamic_partition_policy_list:
dynamic_partition_policy_option [, dynamic_partition_policy_option ...]
dynamic_partition_policy_option:
ENABLE = {true | false}
| TIME_UNIT = {'hour' | 'day' | 'week' | 'month' | 'year'}
| PRECREATE_TIME = {'-1' | '0' | 'n {hour | day | week | month | year}'}
| EXPIRE_TIME = {'-1' | '0' | 'n {hour | day | week | month | year}'}
| TIME_ZONE = {'default' | 'time_zone'}
| BIGINT_PRECISION = {'none' | 'us' | 'ms' | 's'}
動的パーティション管理プロパティパラメータの説明
プロパティ名 |
説明 |
必須 |
変更は可能か |
|---|---|---|---|
| ENABLE | 動的パーティション管理を有効にするかどうかを示します。値は以下のとおりです:
|
いいえ | はい |
| TIME_UNIT | パーティションの時間単位、つまり自動的にパーティション境界を作成する間隔を示します。値は以下のとおりです:
|
はい | いいえ |
| PRECREATE_TIME | 事前作成時間を示します。動的パーティション管理をスケジュールするたびに、パーティションを事前作成し、最大パーティション上界 > now() + precreate_time となるようにします。値は以下のとおりです:
説明
|
いいえ | はい |
| EXPIRE_TIME | パーティションの有効期限を示します。動的パーティション管理をスケジュールするたびに、パーティション上界 < now() - expire_time のすべての期限切れパーティションを削除します。値は以下のとおりです:
|
いいえ | はい |
| TIME_ZONE | 現在時刻と日付型(date、datetime、year型)、時刻型(time型)のパーティションキーのサイズを比較する際に依存するタイムゾーン情報を示します。値は以下のとおりです:
|
いいえ | いいえ |
| BIGINT_PRECISION | bigint型パーティションキーのタイムスタンプ精度を示します。値は以下のとおりです:
|
いいえ | いいえ |
テーブル作成構文の詳細なパラメータ説明については、CREATE TABLEを参照してください。
動的パーティションのパラメータ制限
TIME_UNIT:パーティションキーがdate型の場合、TIME_UNITパラメータにhourを指定できません。パーティションキーがyear型の場合、TIME_UNITパラメータにはyearのみを指定できます。PRECREATE_TIME:最大で2048個のパーティションを事前作成できます。TIME_ZONE:パーティションキーがdate、datetime、またはyear型の場合にのみ、TIME_ZONEパラメータでカスタムタイムゾーンのオフセット値を指定できます。その他の型ではdefaultのみ指定可能です。BIGINT_PRECISION:このパラメータの値をus、ms、sに指定できるのは、パーティションキーの型がbigintの場合のみです。その他のパーティションキー型では、このパラメータの値はnoneのみ指定可能です。TIME_UNIT、TIME_ZONE、BIGINT_PRECISIONは指定後に変更できません。
例
動的パーティションテーブル test_tbl1 を作成し、動的パーティションの属性を以下のように設定します:
- パーティションの境界は毎時に設定します。
- 現在時刻から3時間以内のパーティションを事前に作成します。
- パーティションの上限が現在時刻の1日前より早いパーティションを削除します。
- 時間は北京時間(UTC+8)で判断し、パーティションの境界と有効期限のロジックがこのタイムゾーンに基づくことを保証します。
- パーティションキー
col2はDATETIME型であるため、bigint型のタイムスタンプ精度を設定する必要はありません。
CREATE TABLE test_tbl1 (col1 INT, col2 DATETIME)
DYNAMIC_PARTITION_POLICY(
ENABLE = true,
TIME_UNIT = 'hour',
PRECREATE_TIME = '3 hour',
EXPIRE_TIME = '1 day',
TIME_ZONE = '+8:00',
BIGINT_PRECISION = 'none'
)
PARTITION BY RANGE COLUMNS (col2)(
PARTITION P0 VALUES LESS THAN ('2025-04-15 13:30:00')
);
説明
テーブル作成後の事前パーティション作成および期限切れパーティションの削除は即座に実行されません。次回の動的パーティション管理タスクの自動スケジュールを待つか、手動で動的パーティション管理タスクを1回スケジュールする必要があります。詳細については、動的パーティション管理タスクを参照してください。