ora12700linux,ora-00600 [12700]的故障一般是由于table或index的数据块有错误

ora-00600 [12700]的故障一般是由于table或index的数据块有错误

故障现象:

用户反映,在执行以下一条简单的select命令时报错

select * from in_passenger t where t.hotelcode = 'xxxxx'

其中xxxxx是索引列,不使用索引列则不报错。

处理过程:

1. 查看跟踪文件中发生错误的SQL

2. 对引发错误的表的数据块进行检查,命令如下

analyze table xxxxx validate structure;

如果未发现错误,继续检查表上的索引:

analyze table xxxxx validate structure cascade;

一般经过以上两步,就可以断定是table或是index的错误

3. 本案例中,发现是由于index的数据有误,analyze命令报错,返回ora-00600 12700错误,查看trace文件,提示说:

表中记录数和索引的记录数不相符,比如表有20000rows,而索引中有20500rows

4. 由于这个索引是普通用户的索引,所以重建它:

alter index xxxxx rebuild online;

到此为止,问题解决。

后记:

如果损坏的是数据字典上的索引,则不能重建系统,因为系统会报错“不能更改热系统对象”。在itpub上chensq有一篇文章“ora600 12700故障处理”,提到sys.obj$表上的i_obj2索引损坏的解决情况。

如果i_obj2损坏了,最好是exp数据,然后重建库,但在exp的过程中,也要访问到i_obj2,要禁止访问它,主要是两个办法:

1)所有使用到i_obj2的SQL语句都加hint以禁止它的使用

2)更改optimizer_index_cost_adj,使得访问sys.obj$的执行计划不使用索引,而使用全表扫描的方式。

在chensq的文章中,以上两种方式都取得了成功。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值