Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1239562
  • 博文数量: 350
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 5668
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-23 17:53
文章分类

全部博文(350)

文章存档

2013年(350)

分类: Mysql/postgreSQL

2013-04-25 10:44:32

对于已存在的list表分区修改包含两类操作:添加value值和删除value值,下面分别介绍:

修改list分区--Add Values

从标题即可得知,此命令仅应用于list分区或list子分区,语法也非常简单:

Alter table tbname modify partition/subpartition ptname add values (v1,v2....vn);

举个例子:

JSSWEB> select partition_name,high_value from user_tab_partitions

  2  where table_name='T_PARTITION_LIST';

PARTITION_NAME       HIGH_VALUE

-------------------- --------------------------------------------------

T_LIST_P1            1, 2, 3, 4, 5, 6, 7, 8, 9, 10

T_LIST_P2            21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 11, 12, 13

                     , 14, 15, 16, 17, 18, 19, 20

T_LIST_PD            default

JSSWEB> alter table t_partition_list modify partition t_list_p1 add values (31,33);

表已更改。

JSSWEB> select partition_name,high_value from user_tab_partitions

  2  where table_name='T_PARTITION_LIST';

PARTITION_NAME       HIGH_VALUE

-------------------- --------------------------------------------------

T_LIST_P1            1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 31, 33

T_LIST_P2            21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 11, 12, 13

                     , 14, 15, 16, 17, 18, 19, 20

T_LIST_PD            default

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

JSSWEB> insert into t_partition_list values (32,'a');

已创建 1 行。

JSSWEB> alter table t_partition_list modify partition t_list_p1 add values (32);

alter table t_partition_list modify partition t_list_p1 add values (32)

            *

第 1 行出现错误:

ORA-14324: 所要添加的值已存在于 DEFAULT 分区之中

提示,增加新的列表值不会影响到表中原有的记录,因此不会对索引造成影响。

修改list分区--Drop Values

与上类似,也是只能应用于list分区,不过功能相反,该命令是用来删除指定分区的value值,语法如下:

Alter table tbname modify partition/subpartition ptname drop values (v1,v2....vn);

同样在删除list分区value列值的时候,也必须确认当前分区存在指定的value值,但是没有任何应用该值的记录,有点儿饶是吧,脑袋多转几圈就好了。

举个例子:

JSSWEB> alter table t_partition_list modify partition t_list_p1 drop values (31);

表已更改。

成功执行了是吧,接着来看

JSSWEB> 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 中

出错了吧,这是其中的一种错误情形,即前面说的,要确保当前分区中存在指定的value值,再往下看

JSSWEB> alter table t_partition_list modify partition t_list_p1 add values (31);

表已更改。

JSSWEB> insert into t_partition_list values (31,'b');

已创建 1 行。

JSSWEB> 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-14518: 分区包含的某些行对应于已删除的值

这是另外的一种错误情形,即要确保当前分区的记录中,没有应用了指定value值的记录。

=====================================

查看前面的连载:

(11)--合并表分区

(10)--交换表分区

(9)--删除表分区

(8)--增加和收缩表分区

(7)--怎样管理

阅读(952) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~