PL/SQL_处理例外2(非预定义异常、自定义异常)

处理非预定义例外

为了提高PL/SQL程序的健壮性,应该在PL/SQL应用程序中合理地处理这些Oracle错误,此时就需要使用非预定义例外。使用非预定义例外的步骤如下图所示:
示例如下:
DECLARE
  e_integrity EXCEPTION;
  PRAGMA EXCEPTION_INIT(e_integrity,-2291);
BEGIN
  UPDATE emp SET deptno = &dno WHERE empno = &eno;
  EXCEPTION
    WHEN e_integrity THEN
      dbms_output.put_line('该部门不存在');
END;

处理自定义例外

与预定义例外和非预定义例外不同,自定义例外必须显式触发。使用自定义例外的步骤如下图所示:
示例如下:
DECLARE
  e_integrity EXCEPTION;
  PRAGMA EXCEPTION_INIT(e_integrity,-2291);
  v_no_emp EXCEPTION;
BEGIN
  UPDATE emp SET deptno = &dno WHERE empno = &eno;
  IF SQL%NOTFOUND THEN
    RAISE v_no_emp;
  END IF;
  EXCEPTION
    WHEN e_integrity THEN
      dbms_output.put_line('该部门不存在');
    WHEN v_no_emp THEN
      dbms_output.put_line('该雇员不存在');
END;

使用例外函数

当在PL/SQL块中出现Oracle错误时,通过使用例外函数可以取得错误号以及相关的错误消息,其中函数SQLCODE用于取得Oracle错误号,而SQLERRM则用于取得与之相关的错误信息。另外,通过存储过程、函数和包中使用RAISE_APPLICATION_ERROR可以自定义错误号和错误消息。
1、SQLCODE和SQLERRM
DECLARE
  v_ename emp.ename%TYPE;
BEGIN
  SELECT ename INTO v_ename FROM emp
  WHERE sal = &sal;
  dbms_output.put_line('雇员名:' || v_ename);
  EXCEPTION
    WHEN NO_DATA_FOUND THEN
      dbms_output.put_line('不存在工资为:' || &sal || '的雇员');
    WHEN OTHERS THEN
      dbms_output.put_line('错误号:' || SQLCODE);
      dbms_output.put_line('错误消息:' || SQLERRM);
END;
2、RAISE_APPLICATION_ERROR
该过程用于在PL/SQL应用程序中自定义错误消息。注意,该过程只能在数据库端的子程序(过程、函数、包、触发器)中使用,而不能在匿名块和客户端的子程序中使用。使用该过程的语法如下:
raise_application_error(error_number,message[,{TRUE | FALSE }]);
示例如下:
DECLARE
  v_comm emp.comm%TYPE;
BEGIN
  SELECT comm INTO v_comm FROM emp
  WHERE empno = &eno;
  IF v_comm IS NULL THEN
    RAISE_APPLICATION_ERROR(-20000,'该雇员无补助');
  END IF;
  EXCEPTION
    WHEN NO_DATA_FOUND THEN
      dbms_output.put_line('该雇员不存在');
END;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值