在Oracle中,抛出异常有哪几种方式?
有三种方式可以抛出异常,分别是:
① 通过PL/SQL运行引擎
② 使用RAISE语句
③ 调用RAISE_APPLICATION_ERROR存储过程
当数据库或PL/SQL在运行时发生了错误,此时的异常可以通过PL/SQL运行时的引擎自动抛出异常,这个无需过度关注。第二种是通过RAISE语句抛出异常,语法如下所示:
RAISE exception_name;
显式抛出异常是程序员处理声明的异常的习惯用法,但RAISE不限于声明了的异常,它可以抛出任何异常。比如下面一个订单输入的例子,若当订单大于库存数量,则抛出异常,并且捕获该异常、处理该异常。关键的代码部分如下所示:
DECLARE
INVENTORY_TOO_LOW EXCEPTION;
---其他声明语句
BEGIN
IF ORDER.QTY > INVENTORY.QTY THEN
RAISE INVENTORY_TOO_LOW;
END IF;
EXCEPTION
WHEN INVENTORY_TOO_LOW THEN
ORDER.STATUS := 'INVENTORY_LOW';
END;
第三种抛出异常的办法是通过RAISE_APPLICATION_ERROR语句。RAISE_APPLICATION_ERROR是一个内建函数,它用于抛出一个异常并给异常赋予一个错误号以及错误信息,它将应用程序专有的错误从服务器端转达到客户端应用程序(其它机器上的SQL*Plus或者其它前台开发语言)。该函数可以在PL/SQL程序块的执行部分和异常部分被调用。
RAISE_APPLICATION_ERROR的声明:
RAISE_APPLICATION_ERROR(ERROR_NUMBER IN NUMBER,MESSAGE IN VARCHAR2[,TRUE,FALSE]))
错误号的范围是-20000到-20999,这样就不会与Oracle的任何错误代码发生冲突。错误信息是文本字符串,最多为2048字节。TRUE和FALSE表示是添加(TRUE)进错误堆栈(ERROR STACK)还是覆盖(OVERWRITE)错误堆栈(FALSE)。缺省情况下是FALSE。
RAISE_APPLICATION_ERROR使用示例如下所示:
IF PRODUCT_NOT_FOUND THEN
RAISE_APPLICATION_ERROR(-20123,'INVALD PRODUCT CODE',TRUE);
END IF;
需要说明的一点是,当函数用于触发器并且触发事件在以下情况的时候并不能抛出错误:
① 触发事件为“AFTER STARTUP ON DATABASE”或“BEFORE SHUTDOWN ON DATABASE”;
② 触发事件为“AFTER LOGON ON DATABASE”且用户拥有“ADMINISTER DATABASE TRIGGER”权限;
③ 触发事件为“AFTER LOGON ON SCHEMA”且用户拥有“ALTER ANY TRIGGER”权限。
● 本文作者:小麦苗,只专注于数据库的技术,更注重技术的运用
● 作者博客地址:http://blog.itpub.net/26736162/abstract/1/
● 本系列题目来源于作者的学习笔记,部分整理自网络,若有侵权或不当之处还请谅解
● 版权所有,欢迎分享本文,转载请保留出处
● QQ:646634621 QQ群:618766405
● 题目解答若有不当之处,还望各位朋友批评指正,共同进步
长按下图识别二维码或微信扫描下图二维码来关注小麦苗的微信公众号:xiaomaimiaolhr,学习最实用的数据库技术。




