深入学习分区表及分区索引(8)--增加和收缩表分区

1、增加表分区(addpartition)

增加表分区适应于所有的分区形式,其语法是altertabletbnameaddpartition.....

但是,需要注意对于像list,range这种存在范围值的分区,所要增加的分区值必须要大于当前分区中的最大值(如果当前存在maxvalue或default的分区,addpartition会报错,这种情况只能使用split,后面会讲到),hash分区则无此限制。

例如:

JSSWEB>createtablet_partition_range(idnumber,namevarchar2(50))

2partitionbyrange(id)(

3partitiont_range_p1valueslessthan(10)tablespacetbspart01,

4partitiont_range_p2valueslessthan(20)tablespacetbspart02,

5partitiont_range_p3valueslessthan(30)tablespacetbspart03

6);

表已创建。

JSSWEB>altertablet_partition_range

2addpartitiont_range_p4valueslessthan(40);

表已更改。

Hash和list的语法与上类似,这里不再举例。

注意:

1、对于hash分区,当你执行addpartition操作的时候,oracle会自动选择一个分区,并重新分配部分记录到新建的分区,这也意味着有可能带来一些IO操作。

2、执行altertable时未指定updateindexes子句:

如果是range/list分区,其local索引和global索引不会受影响;

如果是hash分区,新加分区及有数据移动的分区的local索引和glocal索引会被置为unuseable,需要重新编译。

3、复合分区完全适用上述所述规则。

2、收缩表分区(coalescepartitions)

Coalescepartition是个很有意思的分区功能,仅能被应用于hash分区或复合分区的hash子分区,执行之后,会自动收缩当前的表分区,比如某表当前有5个hash分区,执行altertabletbnamecoalescepartitions后就变成4个,再执行一次就变成3个,再执行一次就变2个,再执行一次就...........就报错了:),对于已分区的表至少要有一个分区存在的嘛!

例如:

JSSWEB>selecttable_name,partition_namefromuser_tab_partitions

2wheretable_name='T_PARTITION_HASH';

TABLE_NAMEPARTITION_NAME

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

T_PARTITION_HASHT_HASH_P2

T_PARTITION_HASHT_HASH_P3

T_PARTITION_HASHT_HASH_P4

T_PARTITION_HASHT_HASH_P5

T_PARTITION_HASHT_HASH_P1

JSSWEB>altertablet_partition_hashcoalescepartition;

表已更改。

JSSWEB>selecttable_name,partition_namefromuser_tab_partitions

2wheretable_name='T_PARTITION_HASH';

TABLE_NAMEPARTITION_NAME

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

T_PARTITION_HASHT_HASH_P2

T_PARTITION_HASHT_HASH_P3

T_PARTITION_HASHT_HASH_P4

T_PARTITION_HASHT_HASH_P1

注意,收缩的只是分区,并不会影响到数据,但是视被收缩分区中数据的多少,收缩表分区也会涉及到IO操作。

另外如果你在执行该语句时没有指定updateindexes子句,收缩过程中有数据改动的分区其local索引和glocal索引都会失效,需要重新编译。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值