欢迎光临
我们一直在努力

ORACLE ORA-00600错误的阐述-JSP教程,数据库相关

建站超值云服务器,限时71元/月

oracle ora-00600错误不是你的程序错误.是oracle内部的错误,一般来说,大部分的ora-00600错误均是由oracle

软件的bug所导致,因此对于这样的错误需要及时联系oracle技术支持工程师.对于这种类型的ora-00600错误,

一个简单的处理方式就是打补丁,将数据库升级到一个稳定的版本,另外建议屏蔽某些oracle特性,诸如mts

(multithread server)。但也有部分错误是由

数据库内部的表或索引(包括应用的)结构被损坏所或其他原因所造成。

1:ora-600[12700]表示执行sql语句时对应的某些实体(表/索引)损坏;该

错误的处理方法为:

? 修改init$oracle_sid.ora文件,增加如下几行:

event = “10210 trace name context forever level 10”

event = “10211 trace name context forever level 10”

event = “10231 trace name context forever level 10

? 执行以下语句:

analyze table/index/cluster [name] validate structure;

? 如果怀疑是数据字典损坏,则不能采用以上的方法对表进行分析,

因为在某些平台上执行以上操作将引起系统瘫痪,执行如下存储过程:

dbms_utility.analyze_schema

例2:在对数据库进行读写操作时出现错误:ora-00600:internal error

code,arguments:[4519],[6711],[2],…表示执行sql语句时的对应的实体数据

块[6711]的结构被破坏所引起。该错误的处理方法为:

? 执行如下的package进行分析:

svrmgrl > select dbms_utility.data_block_address_file(6711) from dual;

svrmgrl > select dbms_utility.data_block_address_block(6711) from dual;

查找其对应的block_id和file_id。

? 通过如下的sql命令查找出被破坏的实体类型、owner等:

svrmgrl > select segment_name,segment_type,owner

? from dba_extents

? where file_id=file# and block# between

? block_id and block_id+blocks-1;

? 如果被破坏的对象并非系统表或索引,则可以通过对该数据库对象\r

进行备份后重新创建实体的方法进行。如果出现的错误为系统表或索引,则需要

根据实际情况进行处理。

另外,用resultset来执行插入,更新,删除原则上是可行的,但效率很低,而且无法测试操作是否成功.

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » ORACLE ORA-00600错误的阐述-JSP教程,数据库相关
分享到: 更多 (0)