plsql中异常分为:预定义异常、自定义异常
预定义异常时oracle中系统定义好的异常,大概包含20个左右的异常
自定义异常可以弥补预定义异常不够使用的劣势,又分为:错误编码异常与逻辑异常
使用错误编码异常虽然会显示异常信息,但是不够明确到底是哪个异常产生了,需要上网查询异常的类型,可以将编码异常与自定义的异常名称关联起来,而逻辑异常是可以与我们程序中的异常起到等价的作用的,也就是说我们可以在sql中定义在程序中才有的异常。比较个性化,像我在目标成本控制的代码中自定义的目标成本超限异常一样。
declare
uniqueexception exception;
pragma exception_init(uniqueexception,-00001);
begin
insert into dept values(10,'开发部','上海');
exception
when uniqueexception then
dbms_output.put_line('插入了重复数据,咳咳,真不好~');
end;
--业务逻辑异常
select * from emp;
declare
null_exception exception;
sowtype emp%rowtype;
begin
sowtype.ename:='张三呀';
sowtype.job:='站岗的';
insert into emp(empno,ename,job,sal) values (1101,sowtype.ename,sowtype.job,sowtype.sal);
if sowtype.sal is null then
raise null_exception;
end if;
exception
when null_exception then
dbms_output.put_line('自定义的异常已经生效,你真的好棒~');
end;