zoukankan      html  css  js  c++  java
  • ORA-01502错误成因和解决方法

    这个错误是由于索引失效造成的,重建索引后,问题就解决了。

    我们看到,当使用类似 alter table xxxxxx move tablespace xxxxxxx 命令后,索引就会失效。

    当然,作为测试,也可以直接使用alter index idxt unusable;命令使索引失效,例如:
    SQL> alter index idxt unusable;

    Index altered.

    SQL>

    在这种情况下,我们向表中插入数据看看是什么情况:
    SQL> insert into t values(11);
    insert into t values(11)
    *
    ERROR at line 1:
    ORA-01502: index 'MISC.IDXT' or partition of such index is in unusable state


    SQL>
    我们看到,这时就出现了常见的“ORA-01502: index 'XXXXXXXX' or partition of such index is in unusable state”错误。

    检查一下索引状态,我们会注意到索引已经是“UNUSABLE”了。
    SQL> select index_name,index_type,tablespace_name,table_type,status from user_indexes where index_name='IDXT';

    INDEX_NAME                     INDEX_TYPE                  TABLESPACE_NAME                TABLE_TYPE  STATUS
    ------------------------------ --------------------------- ------------------------------ ----------- --------
    IDXT                           NORMAL                      DATA_DYNAMIC                   TABLE       UNUSABLE

    SQL>

    首先,先设置 “skip_unusable_indexes=false”,也就是不跳过失效索引
    SQL> alter session set skip_unusable_indexes=false;

    Session altered.

    SQL>

    然后重建这个失效的索引
    SQL> alter index idxt rebuild;

    Index altered.

    SQL> select index_name,index_type,tablespace_name,table_type,status from user_indexes where index_name='IDXT';

    INDEX_NAME                     INDEX_TYPE                  TABLESPACE_NAME                TABLE_TYPE  STATUS
    ------------------------------ --------------------------- ------------------------------ ----------- --------
    IDXT                           NORMAL                      DATA_DYNAMIC                   TABLE       VALID

    SQL>
    我们看到重建索引后,索引的状态就正常了。

    现在插入数据,看看是正常:
    SQL> insert into t values(12);

    1 row created.

    SQL> commit;

    Commit complete.

    SQL>
    看来,重建索引才是解决这类问题的彻底的方法。

  • 相关阅读:
    校门外的树
    年龄与疾病
    数组逆序重放
    计算书费
    陶陶摘苹果
    与指定数字相同的数的个数
    上学路线
    NOIP2011 普及組 統計單詞數
    [HAOI2012]音量调节
    [USACO11JAN]利润Profits
  • 原文地址:https://www.cnblogs.com/go-onxp/p/ORA-01502.html
Copyright © 2011-2022 走看看