ORACLE中的系统预定义异常

ORACLE中的系统预定义异常

可以在SQL块中使用EXCEPTION来捕捉异常并且进行处理。Oracle预定义的21个系统异常,如果定义异常能够满足要求,就可以使用他们。如果不满足,则可以定义自己的异常,并且可以使用RAISE EXCEPTION来抛出异常。

序号系统异常名称产生原因
1ACCESS_INTO_NULL未定义对象
2CASE_NOT_FOUNDCASE 中若未包含相应的 WHEN ,并且没有设置 ELSE 时
3COLLECTION_IS_NULL集合元素未初始化
4CURSER_ALREADY_OPEN游标已经打开
5DUP_VAL_ON_INDEX唯一索引对应的列上有重复的值
6INVALID_CURSOR在不合法的游标上进行操作
7INVALID_NUMBER内嵌的 SQL 语句不能将字符转换为数字
8NO_DATA_FOUND使用 select into 未返回行,或应用索引表未初始化的元素时
9TOO_MANY_ROWS执行 select into 时,结果集超过一行
10ZERO_DIVIDE除数为 0
11SUBSCRIPT_BEYOND_COUNT元素下标超过嵌套表或 VARRAY 的最大值
12SUBSCRIPT_OUTSIDE_LIMIT使用嵌套表或 VARRAY 时,将下标指定为负数
13VALUE_ERROR赋值时,变量长度不足以容纳实际数据
14LOGIN_DENIEDPL/SQL 应用程序连接到 oracle 数据库时,提供了不正确的用户名或密码
15NOT_LOGGED_ONPL/SQL 应用程序在没有连接 oralce 数据库的情况下访问数据
16PROGRAM_ERRORPL/SQL 内部问题,可能需要重装数据字典& pl./SQL 系统包
17ROWTYPE_MISMATCH宿主游标变量与 PL/SQL 游标变量的返回类型不兼容
18SELF_IS_NULL使用对象类型时,在 null 对象上调用对象方法
19STORAGE_ERROR运行 PL/SQL 时,超出内存空间
20SYS_INVALID_ID无效的 ROWID 字符串
21TIMEOUT_ON_RESOURCEOracle 在等待资源时超时

对应的错误代码:

大部分错误用负号作为错误号,可以使用SQLCODE内置函数看到错误代码,使用SQLERRM得到异常的内置消息。

序号异常错误代码何时出现
1ACCESS_INTO_NULLORA-06530试图访问未初始化对象的时候出现
2CASE_NOT_FOUNDORA-06592如果定义了一个没有ELSE子句的CASE语句,而且没有CASE语句满足运行时条件时出现该异常
3COLLECTION_IS_NULLORA-06531当程序去访问一个没有进行初始化的NESTED TABLE或者是VARRAY的时候,会出现该异常
4CURSOR_ALREADY_OPENORA-06511游标已经被OPEN,如果再次尝试打开该游标的时候,会出现该异常
5DUP_VAL_ON_INDEXORA-00001如果插入一列被唯一索引约束的重复值的时候,就会引发该异常(该值被INDEX认定为冲突的)
6INVALID_CURSORORA-01001不允许的游标操作,比如关闭一个已经被关闭的游标,就会引发
7INVALID_NUMBERORA-01722给数字值赋非数字值的时候,该异常就会发生,这个异常也会发生在批读取时候LIMIT子句返回非正数的时候
8LOGIN_DENIEDORA-01017程序中,使用错误的用户名和密码登录的时候,就会抛出这个异常
9NO_DATA_FOUNDORA_06548在使用SELECT INTO 结构,并且语句返回NULL值的时候;访问嵌套表中已经删除的表或者是访问INDEX BY表(联合数组)中的未初始化元素就会出现该异常
10NOT_LOGGED_ONORA-01012当程序发出数据库调用,但是没有连接的时候(通常,在实际与会话断开连接之后)
11PROGRAM_ERRORORA-06501当Oracle还未正式捕获的错误发生时常会发生,这是因为数据库大量的Object功能而发生
12ROWTYPE_MISMATCHORA-06504如果游标结构不适合PL/SQL游标变量或者是实际的游标参数不同于游标形参的时候发生该异常
13SELF_IS_NULLORA-30625调用一个对象类型非静态成员方法(其中没有初始化对象类型实例)的时候发生该异常
14STORAGE_ERRORORA-06500当内存不够分配SGA的足够配额或者是被破坏的时候,引发该异常
15SUBSCRIPT_BEYOND_COUNTORA-06533当分配给NESTED TABLE或者VARRAY的空间小于使用的下标的时候,发生该异常(类似于java的ArrayIndexOutOfBoundsException)
16SUBSCRIPT_OUTSIDE_LIMITORA-06532使用非法的索引值来访问NESTED TABLE或者VARRAY的时候引发
17SYS_INVALID_ROWIDORA-01410将无效的字符串转化为ROWID的时候引发
18TIMEOUT_ON_RESOURCEORA-00051当数据库不能安全锁定资源的时候引发
19TOO_MANY_ROWSORA-01422常见错误,在使用SELECT INTO 并且查询返回多个行时引发。如果子查询返回多行,而比较运算符为相等的时候也会引发该异常。
20USERENV_COMMITSCN_ERRORORA-01725只可使用函数USERENV(‘COMMITSCN’)作为INSERT语句的VALUES子句中的顶级表达式或者作为UPDATE语句的SET子句中的右操作数
21VALUE_ERRORORA-06502将一个变量赋给另一个不能容纳该变量的变量时引发
22ZERO_DIVIDEORA-01476将某个数字除以0的时候,会发生该异常
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

睿思达DBA_WGX

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值