oracle分区表拆分,Oracle分区拆分分区问题

我们有一个大约2TB的VLDB,每个日期都会对表进行分区。我们还有这些分区的索引映射。但在2019年,所有截至2019年10月1日的数据都进入一个单独的分区,因为一个输入错误,创建了一个子分区,其值高达2019年10月1日。

我们正在尝试使用分割分区来纠正这个问题,即将数据移动到2019年2月10日之前的单个分区,然后移除空分区并为每个日期创建单个分区。这很管用。

这个问题伴随着索引映射而来,因为从10月1日到12月31日已经存在映射,我们无法删除这些映射。因此,我们试图创建从2月11日到9月30日的映射。由于数据量大,此脚本需要很长时间。而且索引在这之后会进入不可用状态,当我们试图重建索引时,它需要很长时间!!

我们还有更好的办法吗。

代码示例-

CREATE TABLE My_Table (

id NUMBER(9,0) NOT NULL,

source_system VARCHAR(20),

eod_date NUMBER(9,0) NOT NULL,

other columns

)

TABLESPACE XYZ001td

PARTITION BY LIST (source_system)

SUBPARTITION BY RANGE (

eod_date

)

(

PARTITION p_XYZ VALUES ('XYZ')

NOCOMPRESS

(

SUBPARTITION XYZ_20181227 VALUES LESS THAN (20181228) TABLESPACE XYZ_20181227_td,

SUBPARTITION XYZ_20181228 VALUES LESS THAN (20181229) TABLESPACE XYZ_20181228_td,

SUBPARTITION XYZ_20181229 VALUES LESS THAN (20181230) TABLESPACE XYZ_20181229_td,

SUBPARTITION XYZ_20181230 VALUES LESS THAN (20181231) TABLESPACE XYZ_20181230_td,

SUBPARTITION XYZ_20181231 VALUES LESS THAN (20190101) TABLESPACE XYZ_20181231_td

**SUBPARTITION XYZ_20191001 VALUES LESS THAN (20191002) TABLESPACE XYZ_20191001_td,**

SUBPARTITION XYZ_20191002 VALUES LESS THAN (20191003) TABLESPACE XYZ_20191002_td,

SUBPARTITION XYZ_20191003 VALUES LESS THAN (20191004) TABLESPACE XYZ_20191003_td,

)

)

/

CREATE INDEX inx_my_table_01

ON My_table (

source_system,

eod_date

)

TABLESPACE XYZ001td

GLOBAL PARTITION BY HASH (

source_system,

eod_date

)

(

PARTITION XYZ_20181227

TABLESPACE XYZ_20181227_ti

LOGGING,

PARTITION XYZ_20181228

TABLESPACE XYZ_20181228_ti

LOGGING,

PARTITION XYZ_20181229

TABLESPACE XYZ_20181229_ti

LOGGING,

PARTITION XYZ_20181230

TABLESPACE XYZ_20181230_ti

LOGGING,

PARTITION XYZ_20181231

TABLESPACE XYZ_20181231_ti

LOGGING

)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值