Oracle PL/SQL学习之基础篇(2)--例外
1、例外分类:系统例外、自定义例外
(1)系统例外,参见相关API文档
(2)自定义例外
定义自己的例外:就像自定义变量一样,类型为exception
抛出例外:使用raise抛出自定义例外
set serveroutput on
declare
cursor cemp is select ename from emp where deptno=50; pename emp.ename%type; --self define exception
self_no_data_found exception;
begin
open cemp; fetch cemp into pename;
if cemp%notfound then
--throw self define exception
raise self_no_data_found;
end if;
exception
when self_no_data_found then
dbms_output.put_line('执行了自定义异常!');
if cemp%isopen then
dbms_output.put_line('close cursor!');
close cemp;
end if;
when others then
dbms_output.put_line('执行了others异常!');
if cemp%isopen then
close cemp;
end if;
end;
/
运行结果:

2、我们使用游标,然后尝试抓取游标中的一条记录,并判断是否有值,如果有值,将其赋值给临时变量。如果没有值,触发自定义异常。
create or replace function f_user_qr_groupmemberinfo
(i_phonenumber in emp.empno%type, --用户号码
i_memberphonenumber in emp.ename%type, --成员号码
i_result out integer --0:数据库操作异常; 1:查询操作正常 2:没有找到数据
)
return MYPACKAGE.empcursor as
c_groupmemberinfo MYPACKAGE.empcursor; --结果游标
str_sql_selectsql varchar2(32676) := 'select t.empno '
|| 'from emp t '
|| 'where t.empno=:i_phonenumber '
||
'and t.ename=:i_memberphonenumber';
pempno emp.empno%type;
--self define exception
self_no_data_found exception;
temp emp.empno%type;
begin
--查询用户主叫号码组内部id
open c_groupmemberinfo for str_sql_selectsql
using i_phonenumber, i_memberphonenumber;
fetch c_groupmemberinfo into pempno;
if c_groupmemberinfo%notfound then
--throw self define exception
raise self_no_data_found;
end if;
temp := pempno;
i_result := 1;
return c_groupmemberinfo;
--异常
exception
when self_no_data_found then
open c_groupmemberinfo for
select 'X' from dual where 1 = 0;
i_result := 2;
return c_groupmemberinfo;
when others then
open c_groupmemberinfo for
select 'X' from dual where 1 = 0;
i_result := 0;
return c_groupmemberinfo;
end f_user_qr_groupmemberinfo;
结果:

自定义的游标:

Oracle PL/SQL学习之基础篇(2)--例外的更多相关文章
- Oracle PL/SQL学习之基础篇(1)
1.PL/SQL,全称Procedure Language/SQL,过程化sql语言 PL/SQL的程序结构 declare --声明部分(包括变量.光标.例外声明) begin --语句序列(DML ...
- 浅析Oracle PL/SQL 学习--未完待续
这是一篇关于Oracle Pl/SQL数据库编程的课程学习分享... 首先说明几点: 学习这门课程之前,已经学过并且掌握一些基础的SQL语句.数据库结构分析.ER图设计等知识: 这里也只是较为大概地将 ...
- Oracle PL/SQL学习之Hello World(0)
1.PL/SQL是Oracle数据库的一大创举,让一些复杂繁琐的常规主流编程代码做的编码处理过程,只需要在PL/SQL中使用简短的几句代码就可以解决,并且准确高效.那么遵循惯例,我们学习PL/SQL编 ...
- [Oracle] PL/SQL学习笔记
-- 1. 使用一个变量 declare -- Local variables here v_name ); begin -- Test statements here select t.user_n ...
- Oracle PL/SQL编程之基础
1.简介:pl/sql块由三个部分组成:定义部分.执行部分.例外处理部分,如下所示: declare: /*定义部分---定义常量.变量.游标.例外.复杂数据类型 begin /*执行部分---要执行 ...
- Oracle PL/SQL学习之你需要知道的快捷键
1.格式化sql语句 Ctrl+A 然后 Ctrl+F7 2.窗口最大化最小化 首选项-->快捷键-->Maximize Toggle,然后修改成自己熟悉的快捷键设置.
- [强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!)
原文:[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!) [强烈推荐]ORACLE PL/SQL编程详解之七: 程序包的创建与应用(聪明在于学习,天 ...
- 【强烈强烈推荐】《ORACLE PL/SQL编程详解》全原创(共八篇)--系列文章导航
原文:[强烈强烈推荐]<ORACLE PL/SQL编程详解>全原创(共八篇)--系列文章导航 <ORACLE PL/SQL编程详解> 系列文章目录导航 ——通过知识共享树立个人 ...
- 学习《Oracle PL/SQL 实例讲解 原书第5版》----创建账户
通过readme.pdf创建student账户. 以下用sys账户登录时都是sysdba. 一.PL/SQL 登录oracle. SYS/123 AS SYSDBA 账户名:sys:密码:123:作 ...
随机推荐
- MVC--SSM和SSH简介
- jdk10运行springboot项目出现:Type javax.xml.bind.JAXBContext not present
项目由openjdk8.0迁移到jdk10导致的 原因:java9模块化的概念使得JAXB默认没有加载: jaxb-api是存在jdk中的,只是默认没有加载而已,手动引入即可. 推荐方式: <! ...
- mysql 经典错误解决方案 :Incorrect string value 'xE6x95x85xE4xBAx8B...' for column
1.关闭当前服务器2.删除正在使用的数据库drop database 数据库名字;3.查看字符集, SHOW VARIABLES LIKE 'character_set_%'; 把所有latin1的都 ...
- python将字典中的数据保存到文件中
d = {'a':'aaa','b':'bbb'}s = str(d)f = open('dict.txt','w')f.writelines(s)f.close()
- 01-html和head介绍
一.web标准 web准备介绍: w3c:万维网联盟组织,用来制定web标准的机构(组织) web标准:制作网页遵循的规范 web准备规范的分类:结构标准.表现标准.行为标准. 结构:html.表示: ...
- python5-常用模块
collection 模块 # pypi 可以查询python的模块在内置数据类型(dict.list.set.tuple)的基础上,collections模块还提供了几个额外的数据类型:Counte ...
- 【图论】信手拈来的Prim,Kruskal和Dijkstra
关于三个简单的图论算法 prim,dijkstra和kruskal三个图论的算法,初学者容易将他们搞混,所以放在一起了. prim和kruskal是最小生成树(MST)的算法,dijkstra是单源最 ...
- AtCoder - 4351 Median of Medians(二分+线段树求顺序对)
D - Median of Medians Time limit : 2sec / Memory limit : 1024MB Score : 700 pointsProblem Statement ...
- ORACLE EBS xml publisher 报表输出字符字段前部"0"被EXCEL自动去掉问题
http://www.cnblogs.com/lzsu1989/archive/2012/10/17/2728528.html Oracle EBS 提供多种报表的开发和输出形式,由于MS Ex ...
- shell模拟“多线程”
shell中并没有真正意义上的多线程,要实现"多线程"可以启动多个子进程,并将子进程放入后台执行来模拟多线程,最大程度利用CPU性能. 循环中执行并行代码 #!/bin/bas ...