http://biancheng.dnbcw.info/oracle/299114.html
若列表分区表中已经建立了default分区,则不能再增加分区。只能先删除default分区,再增加新分区。删除default分区前可以用交换分区进行备份。
下面是一个小测试:
--1.创建列表分区表
SQL> create table testlp(a, b)
2 partition by list(a)(
3 partition testlp1 values(0) tablespace tp_p1,
4 partition testlp2 values(1) tablespace tp_p2,
5 partition testlp3 values(2) tablespace tp_p3
6 )
7 as select mod(rownum, 3), 1 from user_objects;
表已创建。
SQL> select count(*) from testlp;
COUNT(*)
----------
94
SQL> select count(*) from testlp partition(testlp1);
COUNT(*)
----------
31
SQL> select count(*) from testlp partition(testlp2);
COUNT(*)
----------
32
SQL> select count(*) from testlp partition(testlp3);
COUNT(*)
----------
31
--2.当插入的数据不在分区键值之内,则无法插入
SQL> insert into testlp values(3,3);
insert into testlp values(3,3)
*
ERROR 位于第 1 行:
ORA-14400: 插入的分区关键字未映射到任何分区
--3.可以增加一个default分区,来存储列表以外的数据。
SQL> alter table testlp add partition testlp4 values(default) tablespace tp_p3;
表已更改。
SQL> insert into testlp values(3,3);
已创建 1 行。
SQL> commit;
提交完成。
SQL> select count(*) from testlp partition(testlp4);
COUNT(*)
----------
1
--4.由于存在default分区,不能再增加新的分区
SQL> alter table testlp add partition testlp4 values(3) tablespace tp_p3;
alter table testlp add partition testlp4 values(3) tablespace tp_p3
*
ERROR 位于第 1 行:
ORA-14323: 在 DEFAULT 分区已存在时无法添加分区
--5.那么,我们可以把default分区数据进行备份,然后drop掉,来增加新的分区。
--5.1创建表testlp_temp保存default分区数据,并通过交换分区保存数据。
SQL> create table testlp_temp as select * from testlp where 1 = 0;
表已创建。
SQL> alter table testlp exchange partition testlp4 with table testlp_temp;
表已更改。
SQL> select count(*) from testlp partition(testlp4);
COUNT(*)
----------
0
--5.2drop掉default分区
SQL> alter table testlp drop partition testlp4;
表已更改。
--5.3此时可以增加新的分区了
SQL> alter table testlp add partition testlp4 values(3) tablespace tp_p3;
表已更改。
--5.4我们把default分区也增加上
SQL> alter table testlp add partition testlp5 values(default) tablespace tp_p3;
表已更改。
--5.5此时把备份表testlp_temp中的数据通过交换分区导入分区testlp4
SQL> alter table testlp exchange partition testlp4 with table testlp_temp;
表已更改。
SQL> select count(*) from testlp partition(testlp4);
COUNT(*)
----------