全面学习分区表及分区索引(12)--修改list表分区
对于已存在的list表分区修改包含两类操作:添加value值和删除value值,下面分别介绍:
I : 修改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
2 where table_name = 'T_PART_LIST';
PARTITION_NAME HIGH_VALUE
------------------------------ --------------------------------------------------------------------------------
T_LIST_P1 1
T_LIST_P2 2
SQL> alter table t_part_list modify partition t_list_p2 add values (3,4);
Table altered
SQL> select partition_name ,high_value from user_tab_partitions
2 where table_name = 'T_PART_LIST';
PARTITION_NAME HIGH_VALUE
------------------------------ --------------------------------------------------------------------------------
T_LIST_P1 1
T_LIST_P2 2, 3, 4 //看到了把。
//把DEFAULT分区也添加上。
SQL> alter table t_part_list add partition t_list_p3 values (default) tablespace part03;
Table altered
SQL> select partition_name,high_value from user_tab_partitions
2 where table_name ='T_PART_LIST';
PARTITION_NAME HIGH_VALUE
------------------------------ --------------------------------------------------------------------------------
T_LIST_P1 1
T_LIST_P2 2, 3, 4
T_LIST_P3 default
唯一的限制是注意要添加的新value值不能存在于当前任何分区中,并且当前表也不能存在记录值为新值的记录,特别是当你创建了default分区的时候,有必要先检查一下当前表不存在要添加的值,不然命令执行会出错,例如:
SQL> insert into t_part_list values ( 100,'test');
1 row inserted
SQL> commit;
Commit complete
SQL> select * from t_part_list;
ID NAME
----------- ----------
1 asdfad
2 asfda
100 test
SQL> alter table t_part_list modify partition t_list_p1 add values (100);
alter table t_part_list modify partition t_list_p1 add values (100)
ORA-14324: 所要添加的值已存在于 DEFAULT 分区之中 ------------------此时报错。
提示,增加新的列表值不会影响到表中原有的记录,因此不会对索引造成影响。
II:修改list分区--Drop Values
与上类似,也是只能应用于list分区,不过功能相反,该命令是用来删除指定分区的value值,语法如下:
Alter table tbname modify partition/subpartition ptname drop values (v1,v2....vn);
同样在删除list分区value列值的时候,也必须确认当前分区存在指定的value值,但是没有任何应用该值的记录,有点儿饶是吧,脑袋多转几圈就好了。
SQL> alter table t_part_list modify partition t_list_p2 drop values (4);
Table altered
SQL> select partition_name ,high_value from user_tab_partitions
2 where table_name = 'T_PART_LIST';
PARTITION_NAME HIGH_VALUE
------------------------------ --------------------------------------------------------------------------------
T_LIST_P1 1
T_LIST_P2 2, 3 //这里已经把4给去掉了
T_LIST_P3 default
SQL> alter table t_part_list modify partition t_list_p2 drop values (4);
alter table t_part_list modify partition t_list_p2 drop values (4)
ORA-14313: 值 4 不在分区 T_LIST_P2 中 --------------此时报错。
出错了吧,这是其中的一种错误情形,即前面说的,要确保当前分区中存在指定的value值,再往下看
SQL> select partition_name ,high_value from user_tab_partitions
2 where table_name = 'T_PART_LIST';
PARTITION_NAME HIGH_VALUE
------------------------------ --------------------------------------------------------------------------------
T_LIST_P1 1
T_LIST_P2 2, 3
T_LIST_P3 default
SQL> alter table t_part_list modify partition t_list_p2 add values (10);
Table altered
SQL> insert into t_part_list values (10,'test 10');
1 row inserted
SQL> commit;
Commit complete
SQL> alter table t_part_list modify partition t_list_p2 drop values (10);
alter table t_part_list modify partition t_list_p2 drop values (10)
ORA-14518: 分区包含的某些行对应于已删除的值 -------------又报错!因为表中已经有对应的值。
SQL> delete from t_part_list
2 where id = 10;
1 row deleted
SQL> commit;
Commit complete
SQL> alter table t_part_list modify partition t_list_p2 drop values (10);
Table altered
这是另外的一种错误情形,即要确保当前分区的记录中,没有应用了指定value值的记录。
对于已存在的list表分区修改包含两类操作:添加value值和删除value值,下面分别介绍:
I : 修改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
2 where table_name = 'T_PART_LIST';
PARTITION_NAME HIGH_VALUE
------------------------------ --------------------------------------------------------------------------------
T_LIST_P1 1
T_LIST_P2 2
SQL> alter table t_part_list modify partition t_list_p2 add values (3,4);
Table altered
SQL> select partition_name ,high_value from user_tab_partitions
2 where table_name = 'T_PART_LIST';
PARTITION_NAME HIGH_VALUE
------------------------------ --------------------------------------------------------------------------------
T_LIST_P1 1
T_LIST_P2 2, 3, 4 //看到了把。
//把DEFAULT分区也添加上。
SQL> alter table t_part_list add partition t_list_p3 values (default) tablespace part03;
Table altered
SQL> select partition_name,high_value from user_tab_partitions
2 where table_name ='T_PART_LIST';
PARTITION_NAME HIGH_VALUE
------------------------------ --------------------------------------------------------------------------------
T_LIST_P1 1
T_LIST_P2 2, 3, 4
T_LIST_P3 default
唯一的限制是注意要添加的新value值不能存在于当前任何分区中,并且当前表也不能存在记录值为新值的记录,特别是当你创建了default分区的时候,有必要先检查一下当前表不存在要添加的值,不然命令执行会出错,例如:
SQL> insert into t_part_list values ( 100,'test');
1 row inserted
SQL> commit;
Commit complete
SQL> select * from t_part_list;
ID NAME
----------- ----------
1 asdfad
2 asfda
100 test
SQL> alter table t_part_list modify partition t_list_p1 add values (100);
alter table t_part_list modify partition t_list_p1 add values (100)
ORA-14324: 所要添加的值已存在于 DEFAULT 分区之中 ------------------此时报错。
提示,增加新的列表值不会影响到表中原有的记录,因此不会对索引造成影响。
II:修改list分区--Drop Values
与上类似,也是只能应用于list分区,不过功能相反,该命令是用来删除指定分区的value值,语法如下:
Alter table tbname modify partition/subpartition ptname drop values (v1,v2....vn);
同样在删除list分区value列值的时候,也必须确认当前分区存在指定的value值,但是没有任何应用该值的记录,有点儿饶是吧,脑袋多转几圈就好了。
SQL> alter table t_part_list modify partition t_list_p2 drop values (4);
Table altered
SQL> select partition_name ,high_value from user_tab_partitions
2 where table_name = 'T_PART_LIST';
PARTITION_NAME HIGH_VALUE
------------------------------ --------------------------------------------------------------------------------
T_LIST_P1 1
T_LIST_P2 2, 3 //这里已经把4给去掉了
T_LIST_P3 default
SQL> alter table t_part_list modify partition t_list_p2 drop values (4);
alter table t_part_list modify partition t_list_p2 drop values (4)
ORA-14313: 值 4 不在分区 T_LIST_P2 中 --------------此时报错。
出错了吧,这是其中的一种错误情形,即前面说的,要确保当前分区中存在指定的value值,再往下看
SQL> select partition_name ,high_value from user_tab_partitions
2 where table_name = 'T_PART_LIST';
PARTITION_NAME HIGH_VALUE
------------------------------ --------------------------------------------------------------------------------
T_LIST_P1 1
T_LIST_P2 2, 3
T_LIST_P3 default
SQL> alter table t_part_list modify partition t_list_p2 add values (10);
Table altered
SQL> insert into t_part_list values (10,'test 10');
1 row inserted
SQL> commit;
Commit complete
SQL> alter table t_part_list modify partition t_list_p2 drop values (10);
alter table t_part_list modify partition t_list_p2 drop values (10)
ORA-14518: 分区包含的某些行对应于已删除的值 -------------又报错!因为表中已经有对应的值。
SQL> delete from t_part_list
2 where id = 10;
1 row deleted
SQL> commit;
Commit complete
SQL> alter table t_part_list modify partition t_list_p2 drop values (10);
Table altered
这是另外的一种错误情形,即要确保当前分区的记录中,没有应用了指定value值的记录。