[英]Partition existing table using interval partitioning in Oracle
我想使用间隔分区和列表子分区在oracle 12中对现有表进行分区。 我发现了一些有关如何随后在范围内进行分区的信息,但没有使用间隔分区。 我想告诉数据库第一个分区及其具有的值(日期),他将为表中的所有数据集自动创建其余分区。
ALTER TABLE TEST_TABLE MODIFY
PARTITION BY RANGE(TESTDATE) INTERVAL (NUMTOYMINTERVAL(1, 'MONTH'))
SUBPARTITION BY LIST(COMPANY_NR) (
PARTITION p1 VALUES LESS THAN (TO_DATE('01.01.2018 00:00:00', 'DD.MM.YYYY HH24:MI:SS'))
(
SUBPARTITION P_1 VALUES(1),
SUBPARTITION P_2 VALUES(2)
)
);
这样可以自动创建具有间隔的分区吗? 我在任何地方都找不到任何信息。 如果是的话,我在这里做错了什么? 它说我缺少子分区关键字。
您必须像这样使用SUBPARTITION TEMPLATE:
CREATE TABLE TEST_TABLE (...)
PARTITION BY RANGE (TESTDATE) INTERVAL (NUMTOYMINTERVAL(1, 'MONTH'))
SUBPARTITION BY LIST (COMPANY_NR)
SUBPARTITION TEMPLATE
(
SUBPARTITION P_1 VALUES (1),
SUBPARTITION P_2 VALUES (2)
SUBPARTITION P_others VALUES (DEFAULT)
)
(
PARTITION p1 VALUES LESS THAN (DATE '2018-01-01')
);
您可以在现有表上更改子分区模板,请参阅修改子分区模板。
但是,如果您想更改分区,则必须使用DBMS_REDEFINITION包。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.