plsql异常学习

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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值