修改list表分区!

来源:互联网 发布:淘宝怎么解除绑定手机 编辑:程序博客网 时间:2024/06/06 09:57
对于已存在的list表分区修改包含两类操作:添加value值和删除value值,下面分别介绍:

修改list分区--Add Values
从标题即可得知,此命令仅应用于list分区或list子分区,语法也非常简单:
Alter table tbname modify partition/subpartition ptname add values (v1,v2....vn);
举个例子:

SQL> select partition_name,high_value from user_tab_partitions where table_name='T_PARTITION_LIST';PARTITION_NAME                 HIGH_VALUE------------------------------ ---------------T_LIST_P1                      1, 2, 3, 4, 5,                               6, 7, 8, 9T_LIST_PD                      defaultSQL> alter table t_partition_list modify partition t_list_p1 add values (10,11);表已更改。SQL> alter table t_partition_list modify partition t_list_p1 add values (20,21);表已更改。SQL> select partition_name,high_value from user_tab_partitions where table_name='T_PARTITION_LIST';PARTITION_NAME                 HIGH_VALUE------------------------------ ---------------T_LIST_P1                      1, 2, 3, 4, 5,                               6, 7, 8, 9, 10,                                11, 20, 21T_LIST_PD                      default

唯一的限制是注意要添加的新value值不能存在于当前任何分区中,并且当前表也不能存在记录值为新值的记录,特别是当你创建了default分区的时候,有必要先检查一下当前表不存在要添加的值,不然命令执行会出错。

 

修改list分区--Drop Values
与上类似,也是只能应用于list分区,不过功能相反,该命令是用来删除指定分区的value值,语法如下:
Alter table tbname modify partition/subpartition ptname drop values (v1,v2....vn);
同样在删除list分区value列值的时候,也必须确认当前分区存在指定的value值,但是没有任何应用该值的记录,有点儿饶是吧,脑袋多转几圈就好了。
举个例子:

SQL> alter table t_partition_list modify partition t_list_p1 drop values (21,20);表已更改。SQL> alter table t_partition_list modify partition t_list_p1 drop values (31);alter table t_partition_list modify partition t_list_p1 drop values (31)*第 1 行出现错误:ORA-14313: 值 31 不在分区 T_LIST_P1 中SQL> alter table t_partition_list modify partition t_list_p1 drop values (1);alter table t_partition_list modify partition t_list_p1 drop values (1)            *第 1 行出现错误:ORA-14518: 分区包含的某些行对应于已删除的值
原创粉丝点击