当前位置:  数据库>oracle

Oracle的预定义异常

    来源: 互联网  发布时间:2017-05-10

    本文导语: Oracle在预定义包STANDARD包中提供了一系列的预定义异常。他们是调试Oracle PL/SQL程序的有用工具。大部分错误用负号作为错误号。可以使用SQLCODE内置函数看到错误代码,使用SQLERRM得到异常的内置消息。 异常 错误 何时出现 ...

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_06548 在使用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_ERROR ORA-01725 只可使用函数USERENV('COMMITSCN')作为INSERT语句的VALUES子句中的顶级表达式或者作为UPDATE语句的SET子句中的右操作数 VALUE_ERROR ORA-06502 将一个变量赋给另一个不能容纳该变量的变量时引发 ZERO_DIVIDE ORA-01476 将某个数字除以0的时候,会发生该异常

可以很方便的在SQL块中使用EXCEPTION来捕捉异常并且进行处理(当然,编译异常与在声明块中被抛出的异常除外,一个好的PL/SQL编程习惯是规避在声明块中进行变量的赋值操作)。如果上面的预定义异常能够满足要求,就可以使用他们。如果不满足,则可以像JAVA程序一样,定义自己的异常,并且可以使用RAISE EXCEPTION来抛出异常。


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • 网间Oracle的连接,远程连接Oracle服务器?? iis7站长之家
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,