没有合适的资源?快使用搜索试试~ 我知道了~
命名的系统异常 产生原因 ACCESS_INTO_NULL 未定义对象 CASE_NOT_FOUND CASE 中若未包含相应的 WHEN ,并且没有设置 ELSE 时 COLLECTION_IS_NULL 集合元素未初始化 CURSER_ALREADY_OPEN 游标已经打开 DUP_VAL_ON_INDEX 唯一索引对应的列上有重复的值 INVALID_CURSOR 在不合法的游标上进行操作 ...............................需要请下载
资源推荐
资源详情
资源评论
Oracle 预定义的 21 个系统异常类型
命名的系统异常 产生原因
ACCESS_INTO_NULL
未定义对象
CASE_NOT_FOUND
CASE中若未包含相应的WHEN,并且
没有设置ELSE时
COLLECTION_IS_NULL
集合元素未初始化
CURSER_ALREADY_OPEN
游标已经打开
DUP_VAL_ON_INDEX
唯一索引对应的列上有重复的值
INVALID_CURSOR
在不合法的游标上进行操作
INVALID_NUMBER
内嵌的SQL语句不能将字符转换为数字
NO_DATA_FOUND
使用select into未返回行,或应用索引
表未初始化的元素时
TOO_MANY_ROWS
执行select into时,结果集超过一行
ZERO_DIVIDE
除数为0
SUBSCRIPT_BEYOND_COUN
T
元素下标超过嵌套表或VARRAY的最大
值异常编号:-00001
SUBSCRIPT_OUTSIDE_LIMIT
使用嵌套表或VARRAY时,将下标指定
为负数
VALUE_ERROR
赋值时,变量长度不足以容纳实际数据
LOGIN_DENIED
PL/SQL应用程序连接到oracle数据库
时,提供了不正确的用户名或密码
NOT_LOGGED_ON
PL/SQL应用程序在没有连接oralce数
据库的情况下访问数据
PROGRAM_ERROR
PL/SQL内部问题,可能需要重装数据字
典&pl./SQL系统包
ROWTYPE_MISMATCH
宿主游标变量与PL/SQL游标变量的返
回类型不兼容
SELF_IS_NULL
使用对象类型时,在null对象上调用对
象方法
STORAGE_ERROR
运行PL/SQL时,超出内存空间
SYS_INVALID_ID
无效的ROWID字符串
TIMEOUT_ON_RESOURCE
Oracle在等待资源时超时
下面的异常带有错误代码:
Oracle
在预定义包 STANDARD 包中提供了一系列的预定义异常。他们是调试 Oracle PL/SQL 程序的有
用工具。大部分错误用负号作为错误号。可以使用 SQLCODE 内置函数看到错误代码,使用 SQLERRM
得到异常的内置消息。
异常 错误 何时出现
ACCESS_INTO_NULL ORA-06530
试图访问未初始化对象的时候出现
CASE_NOT_FOUND ORA-06592
如果定义了一个没有 ELSE 子句的 CASE 语句,而且没
有 CASE 语句满足运行时条件时出现该异常
COLLECTION_IS_NULL ORA-06531
当程序去访问一个没有进行初始化的 NESTED TABLE
或者是 VARRAY 的时候,会出现该异常
CURSOR_ALREADY_OPEN ORA-06511
游标已经被 OPEN,如果再次尝试打开该游标的时候,
会出现该异常
DUP_VAL_ON_INDEX ORA-
00001
如果插入一列被唯一索引约束的重复值的时候,就会引
发该异常(该值被 INDEX 认定为冲突的)
INVALID_CURSOR ORA-01001
不允许的游标操作,比如关闭一个已经被关闭的游标,
就会引发
INVALID_NUMBER ORA-01722
给数字值赋非数字值的时候,该异常就会发生,这个异
常也会发生在批读取时候 LIMIT 子句返回非正数的时候
LOGIN_DENIED ORA-01017
程序中,使用错误的用户名和密码登录的时候,就会抛
出这个异常
NO_DATA_FOUND ORA_0654
8
在使用 SELECT INTO 结构,并且语句返回 NULL 值
的时候;访问嵌套表中已经删除的表或者是访问
INDEX BY 表(联合数组)中的未初始化元素就会出
现该异常
NOT_LOGGED_ON ORA-01012
当程序发出数据库调用,但是没有连接的时候(通常,
在实际与会话断开连接之后)
PROGRAM_ERROR ORA-06501
当 Oracle 还未正式捕获的错误发生时常会发生,这是
因为数据库大量的 Object 功能而发生
ROWTYPE_MISMATCH ORA-06504
如果游标结构不适合 PL/SQL 游标变量或者是实际的游
标参数不同于游标形参的时候发生该异常
SELF_IS_NULL ORA-30625
调用一个对象类型非静态成员方法(其中没有初始化对
象类型实例)的时候发生该异常
STORAGE_ERROR ORA-06500
当内存不够分配 SGA 的足够配额或者是被破坏的时候,
引发该异常
SUBSCRIPT_BEYOND_COUNT ORA-06533
当分配给 NESTED TABLE 或者 VARRAY 的空间小于使
用的下标的时候,发生该异常(类似于 java 的
ArrayIndexOutOfBoundsException)
SUBSCRIPT_OUTSIDE_LIMIT ORA-06532
使用非法的索引值来访问 NESTED TABLE 或者
VARRAY 的时候引发
SYS_INVALID_ROWID ORA-01410
将无效的字符串转化为 ROWID 的时候引发
TIMEOUT_ON_RESOURCE ORA-00051
当数据库不能安全锁定资源的时候引发
TOO_MANY_ROWS ORA-
01422
常见错误,在使用 SELECT INTO 并且查询返回多个
行时引发。如果子查询返回多行,而比较运算符为相等
的时候也会引发该异常。
USERENV_COMMITSCN_ERRO
R
ORA-01725
只可使用函数 USERENV('COMMITSCN')作为 INSERT
语句的 VALUES 子句中的顶级表达式或者作为
UPDATE 语句的 SET 子句中的右操作数
VALUE_ERROR ORA-06502
将一个变量赋给另一个不能容纳该变量的变量时引发
ZERO_DIVIDE ORA-01476
将某个数字除以 0 的时候,会发生该异常
可以很方便的在 SQL 块中使用 EXCEPTION 来捕捉异常并且进行处理(当然,编译异常与在声明块中被
抛出的异常除外,一个好的 PL/SQL 编程习惯是规避在声明块中进行变量的赋值操作)。如果上面的预定
义异常能够满足要求,就可以使用他们。如果不满足,则可以像 JAVA 程序一样,定义自己的异常,并且
可以使用 RAISE EXCEPTION 来抛出异常。
剩余18页未读,继续阅读
资源评论
一只小白牛
- 粉丝: 1
- 资源: 6
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功