ORA- , ERROR, ORACLE数据库错误 ,ORA-nnnn
,oerr
概述
本文为数据库错误(如ORA-nnnn等)的概要和一般处理方法的介绍。
ORACLE错误的表示形式
ORACLE数据库表示的错误,通常由3个字母加上5个数字来组成,如:ORA-nnnnn,TNS-nnnnn等,其中:
前3个字母代表错误发生的组件,如:ORA代表是服务器端发生的错误,TNS代表是网络方面发生的错误。
后5个数字则代表错误的具体含义,如:ORA-00001代表违反唯一约束条件等。
ORACLE错误分类
ORACLE数据库错误主要可以分为内部错误和外部错误,也可细分为以下几类:
错误的一般原因和处理方法
对于ORACLE数据库错误,可以通过下面途径了解到简要的错误原因和处理方法。
1.官方在线文档
官方在线文档的错误手册中,对数据库常见的错误进行了简要的错误原因描述和处理意见,在遇到错误时可以第一时间进行查询。
参考:
Home/Database/Oracle/Oracle Database/Release 12.2
Error Messages
https://docs.oracle.com/database/122/ERRMG/toc.htm
在安装了ORACLE数据库软件的机器上,可以通过在命令行中输入以下的命令查看。
oerr <错误组件> <错误号>
例:
对于ORA-00001错误,可以通过如下查询:-bash-4.1$ oerr ora 1
00001, 00000, "unique constraint (%s.%s) violated"
// *Cause: An UPDATE or INSERT statement attempted to insert a duplicate key.
// For Trusted Oracle configured in DBMS MAC mode, you may see
// this message if a duplicate entry exists at a different level.
// *Action: Either remove the unique restriction or do not insert the key.
3.通过安装数据库后的如下文件查看
$ORACLE_HOME/rdbms/mesg/*.msg
所有错误相关的文件:
-bash-4.1$ cd $ORACLE_HOME/rdbms/mesg
-bash-4.1$ ls *.msg
amduus.msg diaus.msg kfedus.msg kopus.msg ocius.msg rmanus.msg udius.msg
asmcmdus.msg expus.msg kfodus.msg kupus.msg opwus.msg sbtus.msg ulus.msg
dbvus.msg gimus.msg kfsgus.msg lcdus.msg oraus.msg smgus.msg
dgmus.msg impus.msg kgpus.msg nidus.msg qsmus.msg udeus.msg
ORA-错误相关的文件为oraus.msg,在Linux环境下可以通过more/cat/tail等命令查看:
tail -20 $ORACLE_HOME/rdbms/mesg/oraus.msg
例:
-bash-4.1$ tail -20 $ORACLE_HOME/rdbms/mesg/oraus.msg
////////////////////////////////////////////////////////////////////////////
65530, 00000, "CELLCACHE feature not supported for IOTs"
// *Document: NO
// *Cause: An attempt was made to enable the CELLCACHE feature for an
// index-organized table.
// *Action: None.
/
65531, 00000, "maximum level reached in index segment with object id %s"
// *Cause: The attempted operation resulted in the number of index levels
// exceeding the maximum allowed.
// *Action: Reduce the size of the relevant index, for example, by using
// compression or partitioning.
/
65535, 00000, "Oracle client cannot handle error code exceeding 65535. Actual error code and message follow:\n"
// *Cause: Oracle server encountered an error whose error code exceeded 65535.
// Older Oracle clients (prior to version 12) cannot handle error
// codes larger than 65535.
// *Action: Actual Oracle error code and error message are a part of the error
// message for ORA-65535. Upgrade Oracle client to version 12 client
// libraries or higher.
通过简要的错误原因和处理方法,基本可以解决80%的问题。 如果需要的话,可以通过如下方法进一步调查。
1.查看告警日志(Alert Log)中服务器是否自动输出更详细的诊断信息及TRACE文件
2.查看错误发生时间附近相关TRACE文件,看是否能够获得有效信息
3.如果数据库服务器没有自动输出诊断信息,可尝试设置错误发生时的诊断事件取得errorstack等相关诊断信息
例如,在ORA-00001错误发生时,输出errorstack诊断信息。
--有效
alter system set events '1 trace name errorstack level 3';
--无效
alter system set events '1 trace name errorstack off';
用碎片化的时间,一点一滴地学习一套系统化的知识。