【PL/SQL练习】自定义异常
由用户自己定义
1、定义异常名称,类型exception
2、举出异常(raise excepttion)
3、捕获异常
SQL> declare
2 e_user_err exception;
3 v_deptno dept.deptno%type := &no;
4 begin
5 update dept set loc='HongKong' where deptno=v_deptno;
6
7 if sql%notfound then
8 raise e_user_err;
9 end if;
10 commit;
11 exception
12 when e_user_err then
13 dbms_output.put_line('This department '||v_deptno|| ' is not in dept table ,please input correct number !');
14 end;
非预定义异常,通过oracle ORA-XXXX错误代码,建立异常捕获!
-------违背了参考性约束 declare
e_emp_remain exception;
pragma exception_init( e_emp_remain ,-2292); v_deptno dept.deptno%type :=&no; begin
delete from dept where deptno=v_deptno;
commit;
exception
when e_emp_remain then
dbms_output.put_line ('Don''t remove this '||v_deptno||' department !'||' , This record is in emp !');
when others then
dbms_output.put_line ('Others error !');
end;
SQL> declare
2 e_emp_remain exception;
3 pragma exception_init( e_emp_remain ,-2291);
4
5 v_empno emp.empno%type :=&n;
6 v_deptno emp.deptno%type :=&nn;
7
8 begin
9 update emp set deptno=v_deptno where empno=v_empno;
10 commit;
11 exception
12 when e_emp_remain then
13 dbms_output.put_line ('Department is not exists !');
14 when others then
15 dbms_output.put_line ('Others error !');
16 end;
获取others中错误代码和错误信息:
sqlcode: oracle 错误代码 sqlerrm: oracle 错误信息
SQL> declare
2 v_code errors.code%type;
3 v_msg errors.msg%type;
4 v_sal emp.sal%type;
5
6 begin
7
8 select sal into v_sal from emp where deptno=&no;
9
10 exception
11 when no_data_found then
12 dbms_output.put_line('No this department ID');
13 when others then
14 dbms_output.put_line('Others error ');
15 v_code := sqlcode;
16 v_msg := sqlerrm;
17 dbms_output.put_line(v_msg);
18
19 insert into errors values(v_code,v_msg);
20 commit;
21 end;
通过捕获的代码建立非预定义异常:
SQL> declare
2 e_emp_err exception;
3 pragma exception_init( e_emp_err ,-1422);
4
5 v_sal emp.sal%type;
6
7 begin
8 select sal into v_sal from emp where deptno=&no;
9 commit;
10 exception
11 when e_emp_err then
12 dbms_output.put_line (' Return rows more than one row !');
13 when others then
14 dbms_output.put_line ('Others error !');
15 end;
【PL/SQL练习】自定义异常的更多相关文章
- PL\SQL结构控制、异常
PL\SQL结构控制 1.IF条件控制语句(三种基本方式+IF语句的嵌套使用) (1)IF... (2)IF...ELSE (3)IF...ELSIF. ...
- Oracle学习笔记十 使用PL/SQL
PL/SQL 简介 PL/SQL 是过程语言(Procedural Language)与结构化查询语言(SQL)结合而成的编程语言,是对 SQL 的扩展,它支持多种数据类型,如大对象和集合类型,可使用 ...
- 【Java EE 学习 29 上】【PL/SQL】【存储过程】【存储函数】【触发器】
一.PL/SQL简介 1.概念:PL/SQL语言是Oracle数据库专用的一种高级程序设计语言,是对标准SQL语言进行了过程化扩展的语言. 2.功能:既能够实现对数据库的操作,也能够通过过程化语言中的 ...
- Oracle中PL/SQL的执行部分和各种流程控制
Oracle中PL/SQL的执行部分和异常部分 一.PL/SQL的执行部分. 赋值语句. 赋值语句分两种,一种是定义一个变量,然后接收用户的IO赋值:另一种是通过SQL查询结果赋值. 用户赋值举例: ...
- Oracle PL/SQL
PL/SQL 简介 PL/SQL 是过程语言(Procedural Language)与结构化查询语言(SQL)结合而成的编程语言,是对 SQL 的扩展,它支持多种数据类型,如大对象和集合类型,可使用 ...
- PL/SQL异常处理
As we all known,程序的错误一般分为两类:编译错误和运行时错误.其中运行时错误被称为异常.PL/SQL语句块中处理异常的部分即为异常处理部分.在异常处理部分,可以指定当特定异常发生时所采 ...
- PL/SQL异常处理方法
PL/SQL异常处理方法 1:什么是异常处理: PL/SQL提供一个功能去处理异常,在PL/SQL块中叫做异常处理,使用异常处理我们能够测试代码和避免异常退出. PL/SQL异常信息包含三个部分: ...
- [Oracle] PL/SQL学习笔记
-- 1. 使用一个变量 declare -- Local variables here v_name ); begin -- Test statements here select t.user_n ...
- 整理课堂笔记 pl/sql orcale异常
1>>>>>异常错误处理 1 >预定义的异常处理 预定义说明的部分 ORACLE 异常错误对这种异常情况的处理,只需在PL/SQL块的异常处理部分,直接引用相应 ...
- ORACLE PL/SQL编程详解
ORACLE PL/SQL编程详解 编程详解 SQL语言只是访问.操作数据库的语言,并不是一种具有流程控制的程序设计语言,而只有程序设计语言才能用于应用软件的开发.PL /SQL是一种高级数据库程序设 ...
随机推荐
- Java-输入输出
1. 流的分类 java.io 1.1 输入和输出流 File类不能访问文件内容本身,需要使用输入/输出流 输入输出流的方向是相对与内存读写的方向. 1.2 字节流和字符流 字节流 InputStea ...
- php接二进制文件
PHP默认只识别application/x-www.form-urlencoded标准的数据类型. 因此,对型如text/xml 或者 soap 或者 application/octet-stream ...
- 借助HTML分别禁用IE8, IE9的兼容视图模式的小技巧
IE 添加了兼容模式,开启后会以低一版本的 IE 进行渲染,但是我就遇到了一种情况,在 IE8 下只有不使用兼容模式页面才能显示正常,下面有个不错的方法可以解决这个问题 从 IE 8 开始,IE 添加 ...
- android学习笔记22——Notification
Notification ==> Notification是显示在手机状态栏的消息,位于手机屏幕的最上方: 一般显示手机当前网络.电池状态.时间等: Notification所代表的是一种全局效 ...
- .NET常用方法——邮件发送
邮件发送类文件,可直接使用: 调用方法(实例化.静态调用): 实例化: string exception = ""; SendEmail.SendEmail SE = new Se ...
- HTML标签使用特写
页面定时刷新标签 //页面定时刷新 <meta http-equiv="> Input标记各种特殊用法 <%--禁止鼠标选择内容--%> <input id=& ...
- [tty与uart]2.tty和uart的函数调用流程
以下是在include/uapi/linux/tty.h中定义了现有的线规号,如果需要定义新的,则需要在后面添加新的 /* line disciplines */ #define N_TTY 0 #d ...
- (三)java的数据类型
java是一种强类型的语言,所谓强类型,意味着每个变量都要有确定的类型,每个表达式也要有明确的类型,包括传递的某些参数.java中从大的方面分有两大数据类型,分别是基本数据类型和引用数据类型,基本数据 ...
- application in 2014
OA WEBSITE ERP ISO ANDROID EF+MVC4+CATCHE+JQuery+js+div+css+web性能优化+webservice+sql2008+设计模式+wcf+多线程 ...
- MVC controller and View
actionresult,jsonresult redirectresult partialview, viewdata, tempdata filter viewdata,只能在当前action中有 ...