Oracle异常处理总结
有语法着色的,大家可以浏览这儿:http://www.ouora.com/post/145.html 为了处理PL/SQL应用程序的各种错误,开发人员可以使用各种类型的异常。 Oracle提供了 1:预定义异常 用于处理常见的Oracle错误 2:非预定义异常 用于处理预定义异常所不能处理的Oracle错误 3:自定义异常 用于处理于Oracle错误无关的其他情况 异常处理部分是以关键字EXCEPTION开始的,语法如下:
异常处理部分从关键字EXCEPTION开始,在异常处理部分使用WHEN字句捕捉各种异常,如果有其他未预定义到的异常,使用WHEN OTHERS THEN字句进行捕捉和处理。 1、 处理预定义异常,这是系统预定的21种类型
2、处理非预定义异常 使用非预定义异常包括三步: 一:在定义部分定义异常名, 二:在异常和Oracle错误之间建立关联, 三:在异常处理部分捕捉并处理异常。 当定义Oracle错误和异常之间的关联关系时,需要使用伪过程EXCEPTION_INIT。 一:首先的定义部分定义异常; 二:使用progmaexception_init(exception_name,exception_number) 在异常和oracle错误之间建立关联, 这时要求用户知道可能出现的错误号(异常函数sqlcode、sqlerrm和raise_application_error); 三:最终在异常处理部分捕捉并处理异常。 下面以更新特定雇员的部门号,并处理ORA-02291错误为例,说明使用非预定义异常的方法。示例如下:
预定义异常和非预定义异常都与Oracle错误有关,并且当出现Oracle错误时会隐含触发相应异常; 而自定义异常与Oracle错误没有任何关联,它是由开发人员为特定情况所定义的异常。 当使用自定义异常时, 一:需要在定义部分(DECLARE)定义异常, 二:再执行部分(BEGIN)触发异常(使用RAISE语句), 三:在异常处理部分(EXCEPTION)捕捉并处理异常。
--4、使用异常函数: Oracle内置函数sqlcode和sqlerrm主要用在others处理器中,分别用来返回oracle的错误代码和错误消息。 一般情况下sqlcode返回负数标识的oracle错误代码,除非错误 为‘ora-01403:no data found’,此时对应的sqlcode为+100, 对于用户自定义的异常,sqlcode返回+1,如果没有异常被触发,sqlcode返回0。
Oracle过程raise_application_error用于在plsql应用程序中自定义错误消息。 注意该过程只能在数据库端的子程序(过程、函数、包、触发器)中使用,而不能在匿名块和客户端的子程序中使用。 语法为raise_application_error(error_number,message[,[true|false]]); 其中 error_number用于定义错误号,该错误号必须在-20000到-20999之间的负整数; message用于指定错误消息,并且该消息的长度不 能超过2048字节; 第三个参数如果为true,则该错误会被放在先前错误堆栈中,如果为false(默认值)则会替代先前所有错误。
--5、plsql编译警告: plsql警告可以分为四类: severe:用于 检查可能出现的不可预料或者错误结果,例如参数的别名问题; performance:用于检查可能引起的性能问题,例如执行insert操作时为 number列提供了varchar2类型数据; informational:用于检查子程序中的死代码; all:用于检查所有警告。 为了数据库可以在编 译plsql子程序时发出警告信息,需要设置初始化参数plsql_warnings。这个参数不仅可以在系统级或者会话级设置,也可以在alter procedure命令中设置。
为了检查是否存在对应警告信息,必须先激活警告检查,然后重新编译子程序, 最后使用show errors命令显示警告错误。
--6、定义Exception时要注意的一些事项 当异常发生时,在块的内部没有该异常处理器时,控制将转到或传播到上一层块的异常处理部分。 没有处理的异常将沿检测异常调用程序传播到外层,当异常被处理并解决或到达程序最外层传播停止。在声明部分抛出的异常将控制转到上一层的异常部分。 用户必须在独立的WHEN子串中为每个异常设计异常处理代码,WHEN OTHERS子串必须放置在最后面作为缺省处理器处理没有显式处理的异常。当异常发生时,控制转到异常部分,ORACLE查找当前异常相应的WHEN..THEN语句,捕捉异常,THEN之后的代码被执行,如果错误陷阱代码只是退出相应的嵌套块,那么程序将继续执行内部块END后面的语句。如果没有找到相应的异常陷阱,那么将执行WHEN OTHERS。在异常部分WHEN 子串没有数量限制。
oracle预定义的异常列表
2008-10-30 16:06
|