ORACLE 分割槽索引UNUSABLE導致的DML操作失敗引起的血案

清風艾艾發表於2018-08-24

    近期,一金融客戶的核心繫統進行索引維護,在建立分割槽索引時,使用了不可見、不可用狀態,但是建立完成後導致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/,如需轉載,請註明出處,否則將追究法律責任。

相關文章