OceanBaseデータベースのOracleモードにおけるパーティション操作には、リパーティション(非パーティションテーブルをパーティション1次テーブルおよびパーティション2次テーブルに変換する)、パーティションの追加、パーティションの削除、およびパーティションのクリアが含まれます。
パーティションの再編成
パーティションの再編成の構文は次のとおりです:
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 を追加するものです。パーティション 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