您好,登錄后才能下訂單哦!
本篇內容主要講解“ORACLE分區索引UNUSABLE導致的DML操作失敗舉例分析”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“ORACLE分區索引UNUSABLE導致的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>
到此,相信大家對“ORACLE分區索引UNUSABLE導致的DML操作失敗舉例分析”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。