Oracle列表分区

今天做了一件错事,总结经验如下吧。

当一张表的列表分区建错时,千万不要直接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;

就可以解开索引了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值