ビジネスニーズに応じて、適切なタイプのパーティションテーブルまたはサブパーティションテーブルを作成できます。
OceanBaseデータベースには、パーティションテーブルと非パーティションテーブルの2種類のテーブルがあります。パーティションテーブルは、テーブルを複数のより小さく管理しやすい部分に分割するものです。
パーティションテーブルの種類
パーティションテーブル
OceanBaseデータベースのOracleモードでサポートされているパーティションテーブルの種類は以下のとおりです:
RANGE型パーティションテーブル
- INTERVAL型パーティションテーブル
LIST型パーティションテーブル
HASH型パーティションテーブル
サブパーティションテーブル
OceanBaseデータベースのOracleモードでは、サブパーティションテーブルは任意の2種類のパーティションタイプの組み合わせが可能です。サポート状況は以下のとおりです:
サブパーティションタイプ |
テンプレートを使用したサブパーティションテーブルの作成 |
テンプレートを使用しないサブパーティションテーブルの作成 |
|---|---|---|
| Range + Range | サポート | サポート |
| Range + List | サポート | サポート |
| Range + Hash | サポート | サポート |
| List + Range | サポート | サポート |
| List + List | サポート | サポート |
| List + Hash | サポート | サポート |
| Hash + Range | サポート | サポート |
| Hash + List | サポート | サポート |
| Hash + Hash | サポート | サポート |
RANGE型のパーティションテーブルを作成する
構文
CREATE TABLE table_name (column_name column_type[, column_name column_type])
PARTITION BY RANGE (column_name[, column_name])
(PARTITION partition_name VALUES LESS THAN(expr)
[, PARTITION partition_name VALUES LESS THAN (expr )...]
[, PARTITION partition_name VALUES LESS THAN (MAXVALUE)]
);
Rangeパーティションを作成する際には、以下のルールに従う必要があります:
各パーティションには
VALUES LESS THAN句があり、パーティションに非包含的な上限値を指定します。パーティションキーの値がこの値以上の場合、次のパーティションにマッピングされます。Rangeパーティションのパーティションキーは式にすることはできません。
最初のパーティションを除き、すべてのパーティションには暗黙の下限値があります。これは前のパーティションの上限値です。
最後のRangeパーティションのみ、
MAXVALUEを上限として定義できます。この値には具体的な数値がなく、他のすべてのパーティションの上限よりも大きく、NULL値も含みます。最後のRangeパーティションにMAXVALUEが指定されている場合、新しいパーティションを追加することはできません。
パラメータの説明
パラメータ |
説明 |
|---|---|
| table_name | テーブル名を指定します。 |
| column_name | 列名を指定します。 |
| column_type | 列のデータ型を指定します。 |
| partition_name | パーティション名を指定します。 |
例
Rangeパーティションテーブル tbl1_log_r を作成します。
obclient> CREATE TABLE tbl1_log_r(log_id INT,log_date DATE NOT NULL DEFAULT SYSDATE)
PARTITION BY RANGE(log_date)
(PARTITION M202001 VALUES LESS THAN(TO_DATE('2020/02/01','YYYY/MM/DD'))
, PARTITION M202002 VALUES LESS THAN(TO_DATE('2020/03/01','YYYY/MM/DD'))
, PARTITION M202003 VALUES LESS THAN(TO_DATE('2020/04/01','YYYY/MM/DD'))
, PARTITION M202004 VALUES LESS THAN(TO_DATE('2020/05/01','YYYY/MM/DD'))
, PARTITION M202005 VALUES LESS THAN(TO_DATE('2020/06/01','YYYY/MM/DD'))
, PARTITION M202006 VALUES LESS THAN(TO_DATE('2020/07/01','YYYY/MM/DD'))
, PARTITION M202007 VALUES LESS THAN(TO_DATE('2020/08/01','YYYY/MM/DD'))
, PARTITION M202008 VALUES LESS THAN(TO_DATE('2020/09/01','YYYY/MM/DD'))
, PARTITION M202009 VALUES LESS THAN(TO_DATE('2020/10/01','YYYY/MM/DD'))
, PARTITION M202010 VALUES LESS THAN(TO_DATE('2020/11/01','YYYY/MM/DD'))
, PARTITION M202011 VALUES LESS THAN(TO_DATE('2020/12/01','YYYY/MM/DD'))
, PARTITION M202012 VALUES LESS THAN(TO_DATE('2021/01/01','YYYY/MM/DD'))
, PARTITION MMAX VALUES LESS THAN (MAXVALUE)
);
Query OK, 0 rows affected
List型のパーティションテーブルを作成する
構文
CREATE TABLE table_name (column_name column_type[,column_name column_type])
PARTITION BY LIST (column_name[, column_name])
(PARTITION partition_name VALUES ( v01 [, v0N])
[,PARTITION partition_name VALUES ( vN1 [, vNN])]
[,PARTITION partition_name VALUES (DEFAULT)]
);
説明
- Listパーティションのパーティションキーは式にすることができません。
- 最後のListパーティションに
DEFAULTが指定されている場合、新しいパーティションを追加できません。
パラメータの説明
パラメータ |
説明 |
|---|---|
| table_name | テーブル名を指定します。 |
| column_name | 列名を指定します。 |
| column_type | 列のデータ型を指定します。 |
| partition_name | パーティション名を指定します。 |
| DEFAULT | 最後のパーティションにのみこの値を指定できます。この値には具体的な数値がなく、他のすべてのパーティションの上限よりも大きく、NULL値も含まれます。 |
例
Listパーティションテーブル tbl1_log_l を作成します。
obclient> CREATE TABLE tbl1_log_l(log_id INT,log_value VARCHAR2(20))
PARTITION BY LIST(log_value)
(PARTITION P01 VALUES ('A'),
PARTITION P02 VALUES ( 'B' ),
PARTITION P03 VALUES ( 'C' )
);
Query OK, 0 rows affected
Hashタイプのパーティションテーブルを作成する
構文
CREATE TABLE table_name (column_name column_type[,column_name column_type])
PARTITION BY HASH(column_name[, column_name]) PARTITIONS partition_count;
パラメータの説明
パラメータ |
説明 |
|---|---|
| table_name | テーブル名を指定します。 |
| column_name | 列名を指定します。 |
| column_type | 列のデータ型を指定します。 |
| partition_count | パーティション数を指定します。 |
説明
Hashパーティションを作成する際、パーティション名を指定しない場合、システムが命名規則に基づいて名前を付けます。パーティションテーブルの場合、各パーティションはそれぞれp0、p1、...、pnという名前が付けられます。
例
Hashパーティションテーブルtbl1_hを作成します。
obclient> CREATE TABLE tbl1_h(col1 INT,col2 VARCHAR(50))
PARTITION BY HASH(col1) PARTITIONS 60;
Query OK, 0 rows affected
テンプレート型サブパーティションテーブルの作成
Oracleモードでは、テンプレート型サブパーティションテーブルを作成するSQL構文は次のとおりです:
CREATE TABLE [IF NOT EXISTS] table_name(column_option_list) partition_option_list;
column_option_list:
column_name column_type [, column_name column_type]
partition_option_list:
PARTITION BY
RANGE(column_name){subpartition_option} (range_partition_list)
| LIST(expression){subpartition_option} (list_partition_list)
| HASH(expression){subpartition_option} { (hash_partition_list)
| PARTITIONS partition_count }
subpartition_option:
SUBPARTITION BY
RANGE(column_name) SUBPARTITION TEMPLATE(range_subpartition_list)
| LIST(expression) SUBPARTITION TEMPLATE(list_subpartition_list)
| HASH(expression) { SUBPARTITION TEMPLATE (hash_subpartition_list)
| SUBPARTITIONS subpartition_count }
range_partition_list:
range_partition [, range_partition ...]
range_partition:
PARTITION partition_name VALUES LESS THAN {(expression_list) | MAXVALUE}
range_subpartition_list:
range_subpartition [, range_subpartition ...]
range_subpartition:
SUBPARTITION subpartition_name VALUES LESS THAN {(expression_list) | MAXVALUE}
list_partition_list:
list_partition [, list_partition ...]
list_partition:
PARTITION partition_name VALUES {(expression_list) | DEFAULT}
list_subpartition_list:
list_subpartition [, list_subpartition ...]
list_subpartition:
SUBPARTITION subpartition_name VALUES {(expression_list) | DEFAULT}
hash_partition_list:
hash_partition [, hash_partition ...]
hash_partition:
PARTITION partition_name
hash_subpartition_list:
hash_subpartition [, hash_subpartition ...]
hash_subpartition:
SUBPARTITION subpartition_name
expression_list:
expression [, expression ...]
column_name_list:
column_name [, column_name ...]
partition_count | subpartition_count:
INT_VALUE
説明
- テンプレート型サブパーティションテーブルでは、各パーティションに含まれるサブパーティションはすべてテンプレートに定義された構造に従います。つまり、すべてのパーティションにおいてサブパーティションの定義は同一です。
- テンプレート型サブパーティションテーブルにおけるサブパーティションの命名規則は
($part_name)s($subpart_name)です。
例えば、以下の t_range_range テーブルでは、p0 の下にある3つのサブパーティションの名前はそれぞれ p0smp1、p0smp2、p0smp3 となります。
obclient> CREATE TABLE t_range_range(col1 INT,col2 INT)
PARTITION BY RANGE(col1)
SUBPARTITION BY RANGE(col2)
SUBPARTITION TEMPLATE
(SUBPARTITION mp1 VALUES LESS THAN(100),
SUBPARTITION mp2 VALUES LESS THAN(200),
SUBPARTITION mp3 VALUES LESS THAN(300)
)
(PARTITION p0 VALUES LESS THAN(2020),
PARTITION p1 VALUES LESS THAN(2021),
PARTITION p2 VALUES LESS THAN(2022)
);
Query OK, 0 rows affected
obclient> SELECT table_name,partition_name,subpartition_name FROM USER_TAB_SUBPARTITIONS;
+---------------+----------------+-------------------+
| TABLE_NAME | PARTITION_NAME | SUBPARTITION_NAME |
+---------------+----------------+-------------------+
| T_RANGE_RANGE | P0 | P0SMP1 |
| T_RANGE_RANGE | P0 | P0SMP2 |
| T_RANGE_RANGE | P0 | P0SMP3 |
| T_RANGE_RANGE | P1 | P1SMP1 |
| T_RANGE_RANGE | P1 | P1SMP2 |
| T_RANGE_RANGE | P1 | P1SMP3 |
| T_RANGE_RANGE | P2 | P2SMP1 |
| T_RANGE_RANGE | P2 | P2SMP2 |
| T_RANGE_RANGE | P2 | P2SMP3 |
+---------------+----------------+-------------------+
9 rows in set
一部のパラメータの説明は以下の表のとおりです。
パラメータ |
説明 |
|---|---|
| table_name | テーブル名を指定します。 |
| column_name | 列名を指定します。 |
| column_type | 列のデータ型を指定します。 |
| partition_name | パーティション名を指定します。 |
| subpartition_name | サブパーティション名を指定します。 |
| INT_VALUE | Hashタイプのサブパーティションの数を指定します。 |
Range + Rangeサブパーティションのテンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_m_rr(col1 INT,col2 INT)
PARTITION BY RANGE(col1)
SUBPARTITION BY RANGE(col2)
SUBPARTITION TEMPLATE
(SUBPARTITION mp0 VALUES LESS THAN(2020),
SUBPARTITION mp1 VALUES LESS THAN(2021),
SUBPARTITION mp2 VALUES LESS THAN(2022)
)
(PARTITION p0 VALUES LESS THAN(100),
PARTITION p1 VALUES LESS THAN(200)
);
Query OK, 0 rows affected
Range + Listサブパーティションのテンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_m_rl(col1 INT,col2 VARCHAR2(50))
PARTITION BY RANGE(col1)
SUBPARTITION BY LIST(col2)
SUBPARTITION TEMPLATE
(SUBPARTITION mp0 VALUES('01'),
SUBPARTITION mp1 VALUES('02'),
SUBPARTITION mp2 VALUES('03')
)
(PARTITION p0 VALUES LESS THAN(100),
PARTITION p1 VALUES LESS THAN(200)
);
Query OK, 0 rows affected
Range + Hashサブパーティションのテンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_m_rh(col1 INT,col2 VARCHAR2(50))
PARTITION BY RANGE(col1)
SUBPARTITION BY HASH(col2) SUBPARTITIONS 5
(PARTITION p0 VALUES LESS THAN(100),
PARTITION p1 VALUES LESS THAN(200)
);
Query OK, 0 rows affected
List + Rangeサブパーティションのテンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_m_lr(col1 INT,col2 varchar2(50))
PARTITION BY LIST(col2)
SUBPARTITION BY RANGE(col1)
SUBPARTITION TEMPLATE
(SUBPARTITION mp0 VALUES LESS THAN(100),
SUBPARTITION mp1 VALUES LESS THAN(200),
SUBPARTITION mp2 VALUES LESS THAN(300)
)
(PARTITION p0 VALUES('01'),
PARTITION p1 VALUES('02')
);
Query OK, 0 rows affected
List + Listサブパーティションのテンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_m_ll(col1 INT,col2 varchar2(50))
PARTITION BY LIST(col1)
SUBPARTITION BY LIST(col2)
SUBPARTITION TEMPLATE
(SUBPARTITION mp0 VALUES('A'),
SUBPARTITION mp1 VALUES('B'),
SUBPARTITION mp2 VALUES('C')
)
(PARTITION p0 VALUES('01'),
PARTITION p1 VALUES('02')
);
Query OK, 0 rows affected
List + Hashサブパーティションのテンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_m_lh(col1 INT,col2 VARCHAR2(50))
PARTITION BY LIST(col1)
SUBPARTITION BY HASH(col2) SUBPARTITIONS 5
(PARTITION p0 VALUES('01'),
PARTITION p1 VALUES('02')
);
Query OK, 0 rows affected
Hash + Rangeサブパーティションのテンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE tbl2_m_hr(col1 INT,col2 INT,col3 INT)
PARTITION BY HASH(col1)
SUBPARTITION BY RANGE(col2)
SUBPARTITION TEMPLATE
(SUBPARTITION sp0 VALUES LESS THAN(100),
SUBPARTITION sp1 VALUES LESS THAN(200),
SUBPARTITION sp2 VALUES LESS THAN(300)
)
PARTITIONS 5;
Query OK, 0 rows affected
Hash + Listサブパーティションのテンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE tbl2_m_hl(col1 INT,col2 INT,col3 INT)
PARTITION BY HASH(col1)
SUBPARTITION BY LIST(col2)
SUBPARTITION TEMPLATE
(SUBPARTITION sp0 VALUES(100),
SUBPARTITION sp1 VALUES(200),
SUBPARTITION sp2 VALUES(300)
)
PARTITIONS 5;
Query OK, 0 rows affected
Hash + Hashサブパーティションのテンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE tbl2_m_hh(col1 INT,col2 INT,col3 INT)
PARTITION BY HASH(col1)
SUBPARTITION BY HASH(col2)
SUBPARTITIONS 3
PARTITIONS 5;
Query OK, 0 rows affected
非テンプレート型サブパーティションテーブルの作成
Oracleモードでは、非テンプレート型サブパーティションテーブルを作成するSQL構文は次のとおりです:
CREATE TABLE [IF NOT EXISTS] table_name(column_option_list) partition_option_list;
column_option_list:
column_name column_type [, column_name column_type]
partition_option_list:
PARTITION BY
RANGE(column_name){subpartition_option}
{ range_partition_option (subpartition_option_list)
[, range_partition_option (subpartition_option_list) ...]
}
| LIST(expression){subpartition_option}
{ list_partition_option (subpartition_option_list)
[, list_partition_option (subpartition_option_list) ...]
}
| HASH(expression) {subpartition_option}
{ hash_partition_option (subpartition_option_list)
[, hash_partition_option (subpartition_option_list) ...]
}
subpartition_option:
SUBPARTITION BY { RANGE(column_name) | LIST(expression) | HASH(expression) }
subpartition_option_list:
range_partition_option_list | list_partition_option_list | hash_partition_option_list
range_partition_option_list:
range_partition_option [, range_partition_option ...]
list_partition_option_list:
list_partition_option [, list_partition_option ...]
hash_partition_option_list:
hash_partition_option [, hash_partition_option ...]
range_partition_option:
SUBPARTITION subpartition_name VALUES LESS THAN range_partition_expr
[,SUBPARTITION subpartition_name VALUES LESS THAN range_partition_expr ...]
list_partition_option:
SUBPARTITION subpartition_name VALUES list_partition_expr
[, SUBPARTITION subpartition_name VALUES list_partition_expr ...]
hash_partition_option_list:
SUBPARTITION subpartition_name
[, SUBPARTITION subpartition_name ...]
説明
非テンプレート型サブパーティションテーブルでは、各パーティション内のサブパーティションを自由に定義できます。つまり、各パーティション内のサブパーティションの定義は同じでも異なっても構いません。
一部のパラメータの説明は以下の表のとおりです。
パラメータ |
説明 |
|---|---|
| table_name | テーブル名を指定します。 |
| column_name | 列名を指定します。 |
| column_type | 列のデータ型を指定します。 |
| partition_name | パーティション名を指定します。 |
| subpartition_name | サブパーティション名を指定します。 |
Range + Rangeサブパーティションの非テンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_f_rr(col1 INT,col2 INT)
PARTITION BY RANGE(col1)
SUBPARTITION BY RANGE(col2)
(PARTITION p0 VALUES LESS THAN(100)
(SUBPARTITION sp0 VALUES LESS THAN(2020),
SUBPARTITION sp1 VALUES LESS THAN(2021)
),
PARTITION p1 VALUES LESS THAN(200)
(SUBPARTITION sp2 VALUES LESS THAN(2020),
SUBPARTITION sp3 VALUES LESS THAN(2021),
SUBPARTITION sp4 VALUES LESS THAN(2022)
)
);
Query OK, 0 rows affected
Range + Listサブパーティションの非テンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_f_rl(col1 INT,col2 VARCHAR2(50))
PARTITION BY RANGE(col1)
SUBPARTITION BY LIST(col2)
(PARTITION p0 VALUES LESS THAN(100)
(SUBPARTITION sp0 VALUES('01'),
SUBPARTITION sp1 VALUES('02')
),
PARTITION p1 VALUES LESS THAN(200)
(SUBPARTITION sp2 VALUES('01'),
SUBPARTITION sp3 VALUES('02'),
SUBPARTITION sp4 VALUES('03')
)
);
Query OK, 0 rows affected
Range + Hashサブパーティションの非テンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_f_rh(col1 INT,col2 VARCHAR2(50))
PARTITION BY RANGE(col1)
SUBPARTITION BY HASH(col2)
(PARTITION p0 VALUES LESS THAN(100)
(SUBPARTITION sp0,
SUBPARTITION sp1
),
PARTITION p1 VALUES LESS THAN(200)
(SUBPARTITION sp2,
SUBPARTITION sp3,
SUBPARTITION sp4
)
);
Query OK, 0 rows affected
List + Rangeサブパーティションの非テンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_f_lr(col1 INT,col2 VARCHAR2(50))
PARTITION BY LIST(col2)
SUBPARTITION BY RANGE(col1)
(PARTITION p0 VALUES('01')
(SUBPARTITION sp0 VALUES LESS THAN(100),
SUBPARTITION sp1 VALUES LESS THAN(200)
),
PARTITION p1 VALUES('02')
(SUBPARTITION sp2 VALUES LESS THAN(100),
SUBPARTITION sp3 VALUES LESS THAN(200),
SUBPARTITION sp4 VALUES LESS THAN(300)
)
);
Query OK, 0 rows affected
List + Listサブパーティションの非テンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_f_ll(col1 INT,col2 varchar2(50))
PARTITION BY LIST(col1)
SUBPARTITION BY LIST(col2)
(PARTITION p0 VALUES ('01', '02')
(SUBPARTITION sp0 VALUES ('A'),
SUBPARTITION sp1 VALUES ('B'),
SUBPARTITION sp2 VALUES ('C')
)
,
PARTITION p1 VALUES ('03', '04')
(SUBPARTITION sp3 VALUES ('A'),
SUBPARTITION sp4 VALUES ('B'),
SUBPARTITION sp5 VALUES ('C')
)
);
Query OK, 0 rows affected
List + Hashサブパーティションの非テンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_f_lh(col1 INT,col2 VARCHAR2(50))
PARTITION BY LIST(col1)
SUBPARTITION BY HASH(col2)
(PARTITION p0 VALUES('01')
(SUBPARTITION sp0,
SUBPARTITION sp1
),
PARTITION p1 VALUES('02')
(SUBPARTITION sp2,
SUBPARTITION sp3,
SUBPARTITION sp4
)
);
Query OK, 0 rows affected
Hash + Rangeサブパーティションの非テンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE tbl2_f_hr(col1 INT,col2 INT,col3 INT)
PARTITION BY HASH(col1)
SUBPARTITION BY RANGE(col2)
(PARTITION p0
(SUBPARTITION sp0 VALUES LESS THAN(100),
SUBPARTITION sp1 VALUES LESS THAN(200)),
PARTITION p1
(SUBPARTITION sp2 VALUES LESS THAN(100),
SUBPARTITION sp3 VALUES LESS THAN(200)
)
);
Query OK, 0 rows affected
Hash + Listサブパーティションの非テンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_f_hl(col1 INT,col2 INT,col3 INT)
PARTITION BY HASH(col1)
SUBPARTITION BY LIST(col2)
(PARTITION p0
(SUBPARTITION sp0 VALUES(1,3),
SUBPARTITION sp1 VALUES(4,7)
),
PARTITION p1
(SUBPARTITION sp2 VALUES(1,3),
SUBPARTITION sp3 VALUES(4,7)
)
);
Query OK, 0 rows affected
Hash + Hashサブパーティションの非テンプレート型セカンダリパーティションテーブルを作成する
例:
obclient> CREATE TABLE t2_f_hh(col1 INT,col2 INT,col3 INT)
PARTITION BY HASH(col1)
SUBPARTITION BY HASH(col2)
(PARTITION p0
(SUBPARTITION sp0,
SUBPARTITION sp1
),
PARTITION p1
(SUBPARTITION sp2,
SUBPARTITION sp3
)
);
Query OK, 0 rows affected
INTERVAL型のパーティションテーブルを作成する
使用上の制限
INTERVALパーティションはパーティションレベルでのみサポートされます。つまり、パーティションテーブルまたはサブパーティションテーブルのパーティションをIntervalパーティションに指定できますが、サブパーティションテーブルのサブパーティションをIntervalパーティションに指定することはできません。
テーブル作成時の定義には、少なくとも1つのRANGEパーティションを含める必要があります。
テーブルにIntervalプロパティを指定する場合、
DYNAMIC_PARTITION_POLICYプロパティ(動的パーティション管理プロパティ)を同時に指定することはできません。パーティションキーは単一の列でなければならず、列の型は
NUMBER、DATE、FLOAT、TIMESTAMPのみをサポートします。注意
NUMBER型は精度の指定をサポートしていません。ステップ幅の式の型は、パーティションキーの列の型と一致している必要があります。
- パーティションキーが数値型の場合、ステップ幅も数値型である必要があります。
- パーティションキーが日付型の場合、ステップ幅は
NUMTOYMINTERVALまたはNUMTODSINTERVAL式である必要があります。
ステップ幅の式は定数でなければならず、正の数でなければなりません。
最初のRANGEパーティションでは、パーティションの上限は
MAX_VALUEにすることはできません。最初のRANGEパーティション名は
SYS_Pで始めることはできません。つまり、ユーザーがテーブルを作成する際のパーティション名は、SYS_Pプレフィックスを含む文字列にすることはできません。複数の最初のRANGEパーティションが存在する場合、パーティションの上限は昇順でなければなりません。
パーティションキーが自動インクリメント列である場合はサポートされていません。
構文
CREATE TABLE ステートメントを使用してInterval型のパーティションテーブルを作成できます。構文は以下のとおりです:
CREATE TABLE table_name table_definition partition_option;
partition_option:
PARTITION BY RANGE (column_name)
INTERVAL (expr)
[subpartition_option]
(range_partition_definition)
range_partition_definition:
PARTITION partition_name VALUES LESS THAN (expr)
subpartition_option:
SUBPARTITION BY RANGE (column_name_list) SUBPARTITION TEMPLATE (range_subpartition_list)
| SUBPARTITION BY LIST (column_name_list) SUBPARTITION TEMPLATE (list_subpartition_list)
| SUBPARTITION BY HASH (column_name_list) hash_subpartition_define
パラメータの説明
パラメータ |
パラメータ説明 |
|---|---|
| table_name | 作成するテーブル名を表します。 |
| table_definition | テーブルの列定義を表します。 |
| column_name | INTERVALサブパーティションキーの列名を表します。サブパーティションキーでサポートされている列型は、NUMBER、FLOAT、DATE、TIMESTAMPです。 |
| INTERVAL (expr) | INTERVALサブパーティションのステップ幅式を表します。
|
| range_partition_definition | 最初のRangeサブパーティションの定義を表します。 |
| column_name_list | セカンダリサブパーティションキーのリストを表します。 |
| range_subpartition_definition | Rangeテンプレートによるセカンダリサブパーティションの定義を表します。 |
| list_subpartition_definition | Listテンプレートによるセカンダリサブパーティションの定義を表します。 |
| hash_subpartition_defition | Hashテンプレートによるセカンダリサブパーティションの定義を表します。 |
例
パーティションキー列の型を
INT、パーティションステップサイズを10に設定した、パーティションIntervalのテーブルを作成します。obclient> CREATE TABLE test_tbl1 (col1 INT, col2 INT) PARTITION BY RANGE (col1) INTERVAL (10) ( PARTITION p0 VALUES LESS THAN (0) );列の型を
DATE、パーティションステップサイズを1か月に設定した、Intervalのテーブルを作成します。obclient> CREATE TABLE test_tbl2 (col1 DATE, col2 INT) PARTITION BY RANGE (col1) INTERVAL (NUMTOYMINTERVAL(1, 'month')) ( PARTITION p0 VALUES LESS THAN (TO_DATE('2025-01-01', 'yyyy-mm-dd')) );パーティションをInterval分区、サブパーティションをRange分区とする、テンプレートのパーティションIntervalのテーブルを作成します。パーティションのステップサイズは10です。
obclient> CREATE TABLE test_tbl3 (col1 INT, col2 INT) PARTITION BY RANGE (col1) INTERVAL (10) SUBPARTITION BY RANGE (col2) SUBPARTITION TEMPLATE ( SUBPARTITION mp0 VALUES LESS THAN (100), SUBPARTITION mp1 VALUES LESS THAN (200) ) ( PARTITION p0 VALUES LESS THAN (0) );