ORACLE 分区索引UNUSABLE导致的DML操作失败引起的血案

    近期,一金融客户的核心系统进行索引维护,在创建分区索引时,使用了不可见、不可用状态,但是创建完成后导致INSERT语句操作失败;经过试验分区索引去除UNUSABLE时,INSERT等DML操作不受影响。

    试验验证如下:

1、创建模拟的分区表

SQL>  CREATE TABLE T_NEW (ID int, TIME date,name varchar2(20)) PARTITION BY RANGE (TIME) 

  (PARTITION P1 VALUES LESS THAN (TO_DATE('2018-1-1', 'YYYY-MM-DD')), 

  PARTITION P2 VALUES LESS THAN (TO_DATE('2018-2-1', 'YYYY-MM-DD')), 

  PARTITION P3 VALUES LESS THAN (TO_DATE('2018-3-1', 'YYYY-MM-DD')), 

  PARTITION P4 VALUES LESS THAN (MAXVALUE));  2    3    4    5  

Table created.

SQL>

2、插入数据测试分区表可用

SQL> insert into t_new values(1,TO_DATE('2018-1-15', 'YYYY-MM-DD'),'hellow');

1 row created.

SQL> 

SQL> commit;

Commit complete.

SQL> select * from t_new;

ID TIME      NAME

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

1 15-JAN-18 hellow

SQL>

3、创建业务变更的不可见不可用分区索引

SQL> create unique index IDX1 on t_new (id, time)  local invisible nologging unusable;

Index created.

SQL> 

4、执行INSERT插入失败,提示:ORA-01502分区索引状态为不可用

SQL> insert into t_new values(1,TO_DATE('2018-3-15', 'YYYY-MM-DD'),'yellow');

  insert into t_new values(1,TO_DATE('2018-3-15', 'YYYY-MM-DD'),'yellow')

*

ERROR at line 1:

ORA-01502: index 'TEST.IDX1' or partition of such index is in unusable state

SQL>

5、重新创建索引去掉UNUSABLE关键字

SQL> drop index idx1;

Index dropped.

SQL>  create unique index IDX1 on t_new (id, time)  local invisible nologging ;

Index created.

SQL>

6、模拟INSERT插入不受影响

SQL> insert into t_new values(1,TO_DATE('2018-3-15', 'YYYY-MM-DD'),'yellow');

1 row created.

SQL> 


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29357786/viewspace-2212709/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/29357786/viewspace-2212709/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值