在PL/SQL代码中,我们除了可以使用Oracle预定义的Exception,还可以自定义属于自己的异常。但是,使用自定义异常要注意的是,异常的声明、定义和抛出场景,都是要编写者手工自己完成。
声明异常类型变量
PL/SQL中,异常Exception可以作为一种变量类型使用。如果需要使用自定义异常,则首先需要在declare声明段中声明出异常类型变量。声明使用EXCEPTION关键字进行。
当我们需要将这个异常抛出的时候,只需要使用raise语句。就可以直接中断当前的代码运行流程,进入Exception处理代码段。在异常处理段中,使用when进行系列匹配,将匹配上的异常变量进行拦截。见下面代码示例:
声明异常类型变量
PL/SQL中,异常Exception可以作为一种变量类型使用。如果需要使用自定义异常,则首先需要在declare声明段中声明出异常类型变量。声明使用EXCEPTION关键字进行。
当我们需要将这个异常抛出的时候,只需要使用raise语句。就可以直接中断当前的代码运行流程,进入Exception处理代码段。在异常处理段中,使用when进行系列匹配,将匹配上的异常变量进行拦截。见下面代码示例:
set serveroutput on size 10000;
set timing on;
declare
n_count number;
too_many exception; --定义一个异常类型变量;
begin
select count(*)
into n_count
from dba_objects;
if (n_count>10000) then
raise too_many; --使用raise抛出异常;
end if;
dbms_output.put_line('Normal Stop !');
exception
when no_data_found then
dbms_output.put_line('No Data Found !');
when too_many then --使用变量名称进行拦截