OceanBaseデータベースのOracleモードにおけるパーティション操作には、再パーティション化(パーティションテーブルではないテーブルをパーティションテーブルまたはコンポジット・パーティションテーブルに変換する)、パーティションの追加、パーティションの削除、およびパーティションのクリアが含まれます。
パーティションの再分割
パーティションの再分割の構文は以下のとおりです:
ALTER TABLE table_name MODIFY partition_option;
注意
現在のバージョンでは、パーティションテーブル以外のテーブルをパーティションテーブルに変換することのみがサポートされています。
パーティションの再分割例
パーティションテーブル以外のテーブルをパーティションテーブルに変換する
obclient> CREATE TABLE tbl1(c1 INT PRIMARY KEY, c2 DATE);
Query OK, 0 rows affected
obclient> ALTER TABLE tbl1 MODIFY PARTITION BY HASH(c1) PARTITIONS 4;
Query OK, 0 rows affected
パーティションテーブル以外のテーブルをパーティションテーブルに変換する(テンプレート化)
obclient> CREATE TABLE tbl2(c1 INT, c2 DATE, PRIMARY KEY(c1, c2));
Query OK, 0 rows affected
obclient> ALTER TABLE tbl2 MODIFY PARTITION BY HASH(c1)
SUBPARTITION BY RANGE (c2)
SUBPARTITION TEMPLATE(
SUBPARTITION p1 VALUES LESS THAN (TO_DATE('2016/02/01','YYYY/MM/DD')),
SUBPARTITION p2 VALUES LESS THAN (TO_DATE('2116/02/01','YYYY/MM/DD'))
);
Query OK, 0 rows affected
パーティションテーブル以外のテーブルをパーティションテーブルに変換する(非テンプレート化)
obclient> CREATE TABLE tbl3(c1 INT, c2 DATE, PRIMARY KEY(c1, c2));
Query OK, 0 rows affected
obclient> ALTER TABLE tbl3 MODIFY PARTITION BY RANGE(c1)
SUBPARTITION BY RANGE(c2) (
PARTITION p0 VALUES LESS THAN(0),
PARTITION p1 VALUES LESS THAN(100));
Query OK, 0 rows affected
パーティションの追加
パーティションの追加の構文は以下のとおりです:
ALTER TABLE table_name ADD PARTITION (partition_definition)
以下の例は、テンプレート化されたコンポジット・パーティションテーブルtbl4にパーティションp3を追加するものであり、パーティションの定義のみを指定する必要があります。コンポジット・パーティションの定義は、テンプレートに従って自動的に埋め込まれます。
obclient> CREATE TABLE tbl4(col1 INT, col2 INT, PRIMARY KEY(col1,col2))
PARTITION BY RANGE(col1)
SUBPARTITION BY RANGE(col2)
SUBPARTITION TEMPLATE
(
SUBPARTITION p0 VALUES LESS THAN (50),
SUBPARTITION p1 VALUES LESS THAN (100)
)
(
PARTITION p0 VALUES LESS THAN (100),
PARTITION p1 VALUES LESS THAN (200),
PARTITION p2 VALUES LESS THAN (300)
);
Query OK, 0 rows affected
obclient> ALTER TABLE tbl4 ADD PARTITION p3 VALUES LESS THAN (400);
Query OK, 0 rows affected
パーティションの削除
パーティションを削除する構文は以下のとおりです:
ALTER TABLE table_name DROP PARTITION partition_name;
パーティションを削除する例:
obclient> ALTER TABLE tbl4 DROP PARTITION p3;
Query OK, 0 rows affected
パーティションのクリーンアップ
パーティションをクリーンアップする構文は以下のとおりです:
ALTER TABLE table_name TRUNCATE PARTITION partition_name;
パーティションをクリーンアップする例:
obclient> ALTER TABLE tbl4 TRUNCATE PARTITION p2;
Query OK, 0 rows affected