最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
ORACLE ORA-00600错误的阐述
时间:2022-07-02 18:15:23 编辑:袖梨 来源:一聚教程网
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;
? 如果被破坏的对象并非系统表或索引,则可以通过对该数据库对象
进行备份后重新创建实体的方法进行。如果出现的错误为系统表或索引,则需要
根据实际情况进行处理。
另外,用ResultSet来执行插入,更新,删除原则上是可行的,但效率很低,而且无法测试操作是否成功.
软件的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;
? 如果被破坏的对象并非系统表或索引,则可以通过对该数据库对象
进行备份后重新创建实体的方法进行。如果出现的错误为系统表或索引,则需要
根据实际情况进行处理。
另外,用ResultSet来执行插入,更新,删除原则上是可行的,但效率很低,而且无法测试操作是否成功.
相关文章
- 人们熟悉的寄居蟹属于以下哪种分类 神奇海洋11月21日答案 11-21
- 第五人格11.22共研服有什么更新 11月22日共研服更新内容介绍 11-21
- 原神恰斯卡怎么培养 11-21
- 无期迷途四星装束是谁 11-21
- 王者荣耀帝丹高中校服怎么获得 11-21
- 光遇姆明季后续版本怎么玩 11-21