default分区表已存在

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(*) ----------
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值