<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    斷點

    每天進步一點點!
    posts - 174, comments - 56, trackbacks - 0, articles - 21

    今天在選擇一條記錄進行做刪除操作時,碰見index失敗的問題,如下:
    處理失敗!錯誤信息:[SQLException  ORA-01502  index  VHL_V6.PK_WEB_APP_TGT_OBJ  or partition of such index is in unusable state ]
    在網上查詢了下,知道原因,就上數據庫查了一下,結果如下:
    1 PK_WEB_APP_TGT_OBJ NORMAL VHL_V6 TABLE UNUSABLE。
    顯然是UNUSABLE狀態,那也就知道原因了,呵呵,解決!

    以下為參考文件:

    SQL> create table t(a number);
    Table created.

    1、現在,我們建立一個唯一索引來看看:
    SQL> create unique index idx_t on t(a);
    Index created.
    SQL> select index_name,index_type,tablespace_name,table_type,status from user_indexes where index_name='T';         
    no rows selected
    SQL> select index_name,index_type,tablespace_name,table_type,status from user_indexes where index_name='IDX_T';
    INDEX_NAME                     INDEX_TYPE                  TABLESPACE_NAME                TABLE_TYPE  STATUS
    ------------------------------ --------------------------- ------------------------------ ----------- --------
    IDX_T                          NORMAL                      DATA_DYNAMIC                   TABLE       VALID
    SQL> insert into t values(1);
    1 row created.
    SQL> commit;
    Commit complete.

    2、將索引手工修改為unusable狀態(模擬發生索引失效的情況):
    SQL> alter index idx_t unusable;
    Index altered.
    SQL>  select index_name,index_type,tablespace_name,table_type,status from user_indexes where index_name='IDX_T';
    INDEX_NAME                     INDEX_TYPE                  TABLESPACE_NAME                TABLE_TYPE  STATUS
    ------------------------------ --------------------------- ------------------------------ ----------- --------
    IDX_T                          NORMAL                      DATA_DYNAMIC                   TABLE       UNUSABLE
    我們看到這是,已經不能正常往表中插入數據:
    SQL> insert into t values(2);
    insert into t values(2)
    *
    ERROR at line 1:
    ORA-01502: index 'MISC.IDX_T' or partition of sUCh index is in unusable state

    3、首先,我們通過重建索引(rebuild index)的方法來解決問題:
    SQL> alter index idx_t rebuild;
    Index altered.
    SQL> select index_name,index_type,tablespace_name,table_type,status from user_indexes where index_name='IDX_T';
    INDEX_NAME                     INDEX_TYPE                  TABLESPACE_NAME                TABLE_TYPE  STATUS
    ------------------------------ --------------------------- ------------------------------ ----------- --------
    IDX_T                          NORMAL                      DATA_DYNAMIC                   TABLE       VALID
    SQL> insert into t values(2);
    1 row created.
    SQL> commit;
    Commit complete.
    SQL>

    4、現在我們再次模擬索引失效(unusable狀態):
    SQL> alter index idx_t unusable;
    Index altered.
    SQL> select index_name,index_type,tablespace_name,table_type,status from user_indexes where index_name='IDX_T';
    INDEX_NAME                     INDEX_TYPE                  TABLESPACE_NAME                TABLE_TYPE  STATUS
    ------------------------------ --------------------------- ------------------------------ ----------- --------
    IDX_T                          NORMAL                      DATA_DYNAMIC                   TABLE       UNUSABLE
    SQL> insert into t values(3);
    insert into t values(3)
    *
    ERROR at line 1:
    ORA-01502: index 'MISC.IDX_T' or partition of such index is in unusable state

    5、然后,看看是否可以通過設置參數skip_unusable_indexes=true來解決問題:
    SQL> alter session set skip_unusable_indexes=true;
    Session altered.
    SQL> insert into t values(3);
    insert into t values(3)
    *
    ERROR at line 1:
    ORA-01502: index 'MISC.IDX_T' or partition of such index is in unusable state
    SQL> select index_name,index_type,tablespace_name,table_type,status from user_indexes where index_name='IDX_T';
    INDEX_NAME                     INDEX_TYPE                  TABLESPACE_NAME                TABLE_TYPE  STATUS
    ------------------------------ --------------------------- ------------------------------ ----------- --------
    IDX_T                          NORMAL                      DATA_DYNAMIC                   TABLE       UNUSABLE
    SQL> alter index idx_t rebuild;
    Index altered.
    SQL> select index_name,index_type,tablespace_name,table_type,status from user_indexes where index_name='IDX_T';
    INDEX_NAME                     INDEX_TYPE                  TABLESPACE_NAME                TABLE_TYPE  STATUS
    ------------------------------ --------------------------- ------------------------------ ----------- --------
    IDX_T                          NORMAL                      DATA_DYNAMIC                   TABLE       VALID
    SQL> insert into t values(3);
    1 row created.
    SQL> commit;
    Commit complete.
    SQL>

    總結:對于unique index,通過簡單的設置參數是不能解決問題的,要解決unique index 失效的問題,只能通過重建索引來實現。

    資料引用:http://www.knowsky.com/388811.html


    posted @ 2009-09-26 21:36 斷點 閱讀(80) | 評論 (0)
    主站蜘蛛池模板: 日本黄网站动漫视频免费| 一区二区三区无码视频免费福利 | 无码日韩人妻av一区免费| 亚洲一区二区三区日本久久九| 免费观看久久精彩视频| 久久久久久久久亚洲 | 在线毛片片免费观看| 亚洲精品美女久久久久99| 中国人免费观看高清在线观看二区 | 亚洲成AV人片在线观看| 久久伊人免费视频| 久久精品国产亚洲AV香蕉| 30岁的女人韩剧免费观看| 亚洲a∨无码男人的天堂| 国内自产拍自a免费毛片| 亚洲AV无码一区二区三区鸳鸯影院 | a一级毛片免费高清在线| 亚洲三区在线观看无套内射| 国产在线观看免费av站| 亚洲成人在线电影| 国产成人精品免费视| 亚洲午夜成人精品无码色欲| 日韩高清在线免费看| 一级毛片免费不卡| 亚洲av成人无码久久精品| 波多野结衣在线免费观看| 亚洲熟女综合色一区二区三区| 免费va在线观看| 久久免费精品视频| 在线综合亚洲欧洲综合网站| 亚洲第一黄色网址| 男人进去女人爽免费视频国产| 亚洲一区二区免费视频| 波多野结衣一区二区免费视频| a毛片久久免费观看| 亚洲三级在线播放| 亚洲精品老司机在线观看| 亚洲视频免费在线看| 美女视频黄a视频全免费网站一区| 亚洲成A∨人片在线观看不卡| 又粗又大又黑又长的免费视频|