Oracle的PL_SQL的异常处理
--什么是异常
--异常是在PL/SQL运行过程中有可能出现的错误。 --执行异常的语句
exception
when [异常] when
--异常输出信息。 --Oracle的预定义异常
CASE_NOT_FOUND ora-06592
--case语句中,when子句没有匹配的条件,而且没有else语句,会触发该异常。
NO_DATA_FOUND ORA-01403
--select..into语句没有返回记录,触发该异常
TOO_MANY_ROWS ORA-01422
--select..into语句返回记录多于一条,触发该异常
DUP_VAL_ON_INDEX ORA-00001
--表中唯一索引所对应的列上出现重复值时,引发该异常
VALUE_ERROR ORA-06502
--赋值时,如果变量长度不够,引发该异常
ZERO_DIVIDE ORA-01476
--除数为零时引发的异常
STORAGE_ERROR ORA-06500
--内容溢出或破坏引发该异常
TIMEOUT_ON_RESOURCE ORA-00051
--等待资源超时引发该异常
CURSOR_ALREADY_OPEN ORA-06511
--打开一个已经打开的游标引发该异常 --非预定义异常
1、声明一个异常的名称。
2、把这个异常名称和异常的编号相关联。
--实例
declare
v_t varchar2(5);
v_tt varchar2(3);
tt_8899_exp exception;--声明异常
pragma exception_init(tt_8899_exp,-8899);--exception_init(异常名称,异常代码) begin
v_t:=''; case v_t
when '' then
dbms_output.put_line('');
end case; exception
when CASE_NOT_FOUND then
dbms_output.put_line('字符串超标');
dbms_output.put_line(SQLERRM);--输出异常信息
dbms_output.put_line(SQLCODE);--输出异常的代码
rollback;
end; --自定义异常
declare
v_t number(10); tt_8899_exp exception;--声明异常
pragma exception_init(tt_8899_exp,-8899);--exception_init(异常名称,异常代码) begin
v_t:=-1;
if v_t<0 then
raise tt_8899_exp;--启动自定义异常tt_8899_exp
end if; exception
when CASE_NOT_FOUND then
dbms_output.put_line(SQLERRM);--输出异常信息
dbms_output.put_line(SQLCODE);--输出异常的代码
when tt_8899_exp then
dbms_output.put_line('字符串超标');
dbms_output.put_line(SQLERRM);--输出异常信息
dbms_output.put_line(SQLCODE);--输出异常的代码
rollback;
end;
Oracle的PL_SQL的异常处理的更多相关文章
- Oracle客户端PL_SQL的安装
Oracle数据库的操作大多还是在客户端完成的,因此在众多的客户端软件中我选择了PL_SQL,一下谈谈PL_SQL的基本安装和操作,以及在操作中碰到的一些问题: 1. 首先下载PL_SQL客户端软件, ...
- Oracle 学习笔记 17 -- 异常处理(PL/SQL)
程序异常是在操作期间正常,出现在节目的准备过程是不可避免的例外.但是,必须有一个相应的异常处理机 制,以保证程序的正常运行.PL/SQL程序运行过程中出现的错误.称为异常. 一个优秀的程序都应该可以正 ...
- oracle数据库中的异常处理
create or replace procedure prc_get_sex (stuname student.name%type) as stusex student.sex%type; begi ...
- Oracle的PL_SQL的结构
--PL/SQL的结构 declare --声明变量和常量关键字 v_name nvarchar2(); v_age integer;--常规变量声明 v_product table_name.col ...
- Oracle 异常处理汇总
Oracle 异常处理汇总 1.plsql无法连接 安装oracle,中间录入密码,用户是:sys,pass: 录入的密码. 连接数据库,建议创建新的用户,最好别直接用sys 安装完毕,则需要配置Ne ...
- Oracle 游标示例,带异常处理
Oracle游标示例一则,带异常处理. DECLARE CURSOR c_dl IS SELECT ID, NSRSBH, WSPZXH, ZXYY_DM, HZRQ, SWJG_DM, GXSJ F ...
- Oracle 存储过程异常处理
Oracle 存储过程异常处理 1.异常的优点 如果没有异常,在程序中,应当检查每个命令的成功还是失败,如 BEGIN SELECT ... -- check for ’no data f ...
- Oracle 11g RAC环境下Private IP修改方法及异常处理
Oracle 11g RAC环境下Private IP修改方法及异常处理 Oracle 11g RAC环境下Private IP修改方法及异常处理 一. 修改方法 1. 确认所有节点CRS服务以启动 ...
- Oracle基础 PL-SQL编程基础(4) 异常处理
异常处理: 即使良好的PL-SQL程序也会遇到错误或者未预料的事件,一个优秀的程序都应该能够处理各种出错情况,尽可能的从错误中恢复.程序在运行时出现的错误成为异常.发生异常后,语句讲终止执行,PLSQ ...
随机推荐
- LeetCode226 InvertBinaryTree Java题解
题目: Invert a binary tree. 4 / \ 2 7 / \ / \ 1 3 6 9 to 4 / \ 7 2 / \ / \ 9 6 3 1 解答: 遍历每个节点 直接交换他们的 ...
- CSS基础2——选择器
前面说过样式规则.也知道了样式规则语法形式为:选择器+声明块 如:div{ color:black:padding:10px; } div即表示选择器(此处是元素选择器),花括号里的内容就是声明块 ...
- 实际项目中,看 ECharts 和 HighCharts 渲染性能对比,表面看衣装,本质看内功!!!
最近做项目,使用的是echarts显示图表数据,但是数据量比较多的时候,有卡顿的情况.后来同事拿echarts和HighCharts做了对比,仅供大家参考.同时感谢同事做的工作. 一.查询1天的源数据 ...
- MBA人物俞洪敏:亿万富翁的生活表
我的智商非常一般,就是比别人勤奋.我的脑袋不属于特别笨的那种,但肯定也不是顶尖聪明的类型.在北大的50个同学当中,我的智商应该属于中下水平,这说明我不是顶尖高智商. 我的勤奋一般人跟不上.我平均每天工 ...
- iOS 控制器title和tabbar的title设置问题
iOS 设置tabbarItem的title的是通过 controller.tabBarItem.title = @"标题" iOS 设置导航栏控制器title通过 contoll ...
- member access within misaligned address 0x000000000031 for type 'struct ListNode', which requires 8 byte alignment
在做LeetCode的two sum题目的时候,提交代码遇到了如题的runtime error,后来在一篇博客上看到了解决方法. 现有如下结构体: struct ListNode { int val; ...
- 从sql走向linq的我撞死在起点上
[本文纯个人理解,错误轻喷,非常希望能有大神指点] A left (outer) join B on A.bid=B.id 上面这句话叫做左连接,原因是left(左)join(加入,连入)被译为左连接 ...
- display getSize()
If you want the the display dimensions in pixels you can use getSize: Display display = getWindowMan ...
- poj2816
Popular Cows Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 29799 Accepted: 12090 De ...
- config相关操作(转)
转自:http://www.cnblogs.com/kissdodog/archive/2013/04/16/3025315.html,这是一个专题,感觉比较好,有空可以看与一下 System.Con ...