今天做了一件错事,总结经验如下吧。
当一张表的列表分区建错时,千万不要直接drop PARTITION ,否则将导致该分区的数据丢失,而且不可恢复,深刻教训啊,现在还不知道怎么渡过这个难关啊,害怕ing.
可以采取的方法:(以范围分区举例,此处以城市区号为例分区)
1.例如原来的分区分到了598,这样599就无法插入,现在要新建一个分区在600(NP),然后将598的分区合并到600中。后面将597-591得分区都合并至600中,新建、合并语句如下:
ALTER TABLE sales ADD PARTITION NP
VALUES LESS THAN 600 TABLESPACE ts_sale2000q1;
alter table sales merge partitons SM,NP into partiton NP;
2.将600的分区进行拆分,从599开始拆分,直至拆分到591
ALTER TABLE sales
SPLIT PARTITON NP
AT 599 INTO (SM,NP) ;
这样逐步循环就能实现拆分了。
3.因为Oracle默认在修改分区时,会设置索引为unuseable状态,所以在处理完后,可以重建所以
例如该表有一个所以zd_index
则alter index zd_index rebuild;
就可以解开索引了