① 通过PL/SQL运行引擎

② 利用RAISE语句

③ 调用RAISE_APPLICATION_ERROR存储过程

php抛出异常日常平凡总结在Oracle中抛出异常有哪几种方法 Ruby

当数据库或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是一个内建函数,它用于抛出一个非常并给非常授予一个缺点号以及缺点信息,它将运用程序专有的缺点从做事器端转达到客户端运用程序(其它机器上的SQLPlus或者其它前台开拓措辞)。
该函数可以在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 THENRAISE_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”权限。

后面会分享更多关于运维DBA方面的内容,感兴趣的朋友可以关注下~