打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Oracle PL/SQL开发基础(第三十一弹:自定义异常)

声明异常

如:

DECLARE     e_nodeptno EXCEPTION;BEGIN    NULL;END;
  • 1
  • 2
  • 3
  • 4
  • 5

异常的声明跟变量的声明非常相似,其类型为EXCEPTION。不过异常是一种错误的表示形式,而不是一个真正的变量,因此不能在赋值语句或SQL语句中使用异常,但是异常和变量的作用范围和规则是相同的。

作用域范围

  • 在同一个块中不能声明一个异常两次,但是可以在不同的块中声明相同的异常。
  • 在一个块中声明的异常在本块中和其子块中可见,也就是说内层块可以引用在外层块和本块中定义的异常,但是不能引用在子块中定义的异常。
  • 如果在子块重新声明外部块中同名的异常,将覆盖外部块中的全局异常,使得子块不能引用外部块中的全局异常,但是可以在标签块中声明相同的异常。

抛出异常

预定义异常是当有关Oracle错误产生时,由Oracle隐式抛出的;自定义异常需要显式地使用RAISE进行抛出。
不过RAISE也可以抛出预定义的异常。
如:

DECLARE   e_nocomm   EXCEPTION;                     --自定义的异常   v_comm     NUMBER (10, 2);                --临时保存提成数据的变量   v_empno    NUMBER (4)     := &empno;      --从绑定参数中获取员工信息BEGIN   SELECT comm INTO v_comm FROM emp WHERE empno = v_empno;  --查询并获取员工提成   IF v_comm IS NULL                         --如果没有提成   THEN       RAISE e_nocomm;                        --触发异常   END IF;EXCEPTION   WHEN OTHERS THEN                            --OTHERS必须单独出现      DBMS_OUTPUT.put_line ('错误编码:'||SQLCODE||' 错误消息:'||SQLERRM(100));        RAISE;                                   --重新抛出异常              END;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

处理异常

如:

DECLARE     e_nocomm EXCEPTION;    ...BEGIN    ...EXCEPTION     WHEN e_nocomm THEN         ...    WHEN NO_DATA_FOUND THEN        ...    WHEN OTHERS THEN         ...END;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
ORACLE数据库PROC编程经验介绍
Oracle 10g的使用【SQLPLUS操作大全】
Oracle笔记 六、PL/SQL简单语句块、变量定义
详解Oracle数据库如何查找未使用绑定变量的SQL语句
[oracle编程]pl/sql
mybatis抛出ORA-01745
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服