PL/SQL_处理例外2(非预定义异常、自定义异常)
来源:互联网 发布:软件项目保密管理制度 编辑:程序博客网 时间:2024/05/20 21:19
处理非预定义例外
为了提高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 0
- PL/SQL_处理例外2(非预定义异常、自定义异常)
- PL/SQL_处理例外1(预定义例外)
- Oracle 10g处理例外(即sql异常)学习二——自定义例外和非预定义例外
- Oracle PL/SQL异常处理(非预定义错误)
- 【Oracle】PL/SQL 非预定义异常、自定义异常处理、RAISE_APPLICATION_ERROR
- 【Oracle】PL/SQL 非预定义异常、自定义异常处理、RAISE_APPLICATION_ERROR
- C#自定义异常处理(自定义例外)
- pl/sql预定义异常处理
- PL/SQL_异常
- PL/SQL_异常
- 非预定义的异常处理
- Oracle 10g处理例外(即sql异常)学习一——预定义例外,即常见例外
- 非预定义异常
- Oracle异常处理及举例(Oracle预定义异常和自定义异常)
- java异常(例外)处理
- oracle pl/sql 例外(exception) 异常
- PL/SQL预定义例外
- oracle--非预定义异常
- 堆排序
- 使用Stopwatch类计算代码运行时间
- JavaWeb:报错信息The superclass "javax.servlet.http.HttpServlet" was not found on the Java Build Path
- 克里米亚正式加入俄罗斯联邦
- 线程私有存储空间--pthread_key_t
- PL/SQL_处理例外2(非预定义异常、自定义异常)
- SSH的端口转发:本地转发Local Forward和远程转发Remote Forward
- SIPp之认证注册
- 关于ffmpeg的例子muxing.c
- 防御DDoS攻击实用指南
- readWriteLock并发map与concurrentHashMap对比
- 能触控才是真的好 热卖Win8触控本大搜罗
- 迭代器的初识
- hdu 1026 Ignatius and the Princess I(优先队列+BFS)