--什么是异常
--异常是在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的异常处理的更多相关文章

  1. Oracle客户端PL_SQL的安装

    Oracle数据库的操作大多还是在客户端完成的,因此在众多的客户端软件中我选择了PL_SQL,一下谈谈PL_SQL的基本安装和操作,以及在操作中碰到的一些问题: 1. 首先下载PL_SQL客户端软件, ...

  2. Oracle 学习笔记 17 -- 异常处理(PL/SQL)

    程序异常是在操作期间正常,出现在节目的准备过程是不可避免的例外.但是,必须有一个相应的异常处理机 制,以保证程序的正常运行.PL/SQL程序运行过程中出现的错误.称为异常. 一个优秀的程序都应该可以正 ...

  3. oracle数据库中的异常处理

    create or replace procedure prc_get_sex (stuname student.name%type) as stusex student.sex%type; begi ...

  4. Oracle的PL_SQL的结构

    --PL/SQL的结构 declare --声明变量和常量关键字 v_name nvarchar2(); v_age integer;--常规变量声明 v_product table_name.col ...

  5. Oracle 异常处理汇总

    Oracle 异常处理汇总 1.plsql无法连接 安装oracle,中间录入密码,用户是:sys,pass: 录入的密码. 连接数据库,建议创建新的用户,最好别直接用sys 安装完毕,则需要配置Ne ...

  6. Oracle 游标示例,带异常处理

    Oracle游标示例一则,带异常处理. DECLARE CURSOR c_dl IS SELECT ID, NSRSBH, WSPZXH, ZXYY_DM, HZRQ, SWJG_DM, GXSJ F ...

  7. Oracle 存储过程异常处理

    Oracle 存储过程异常处理 1.异常的优点    如果没有异常,在程序中,应当检查每个命令的成功还是失败,如  BEGIN  SELECT ...  -- check for ’no data f ...

  8. Oracle 11g RAC环境下Private IP修改方法及异常处理

    Oracle 11g RAC环境下Private IP修改方法及异常处理 Oracle 11g RAC环境下Private IP修改方法及异常处理 一. 修改方法 1. 确认所有节点CRS服务以启动 ...

  9. Oracle基础 PL-SQL编程基础(4) 异常处理

    异常处理: 即使良好的PL-SQL程序也会遇到错误或者未预料的事件,一个优秀的程序都应该能够处理各种出错情况,尽可能的从错误中恢复.程序在运行时出现的错误成为异常.发生异常后,语句讲终止执行,PLSQ ...

随机推荐

  1. 浅谈C/C++堆栈指引——C/C++堆栈

    C/C++堆栈指引 Binhua Liu 前言 我们经常会讨论这种问题:什么时候数据存储在飞鸽传书堆栈(Stack)中.什么时候数据存储在堆(Heap)中.我们知道.局部变量是存储在堆栈中的.debu ...

  2. Windows进程间通信--共享内存映射文件(FileMapping)--VS2012下发送和接收

    之前以为两个互不相关的程序a.exe b.exe通信就只能通过网络,人家说可以通过发消息,我还深以为不然,对此,我表示万分惭愧. 之前课本上说的进程间通信,有共享内存.管道等之类的,但没有自己操刀写过 ...

  3. PorterDuffXferMode不对的真正原因PorterDuffXferMode深入试验)

    菜鸡wing遇敌PorterDuffXferMode,不料过于轻敌,应战吃力. 随后与其大战三天三夜.三百余回合不分胜负. 幸得 @咪咪控 相助,侥幸获胜. keyword:PorterDuffXfe ...

  4. C语言中的main函数以及main函数是如何被调用的

    main函数是C语言中比较特殊的函数,C程序总是从main函数开始执行,main函数的原型是: int main(int argc, char *argv[]); 其中argc是命令行参数的个数,ar ...

  5. 基于树莓派3B+Python3.5的OpenCV3.4的配置教程

    https://www.cnblogs.com/Pyrokine/p/8921285.html

  6. 再理解 as3.0接口

    As3.0 接口的理解与运用 1.把接口当作"类"来理解.你easy接受她. 我们看她的标准结构: package 包路径{ public interface 接口名称{ func ...

  7. jquery实现全选、全消、反选功能

    HTML代码: <input type="checkbox" name="checkbox" class="A" /> 使用按钮 ...

  8. Lumen开发:lumen源码解读之初始化(5)——注册(register)与启动(boot)

    版权声明:本文为博主原创文章,未经博主允许不得转载. register()是在服务容器注册服务, bootstrap/app.php /** * 注册外部服务 */ $app->register ...

  9. elipse开发环境搭建(Java+C++)

    目的:搭建可用于java和C++开发的eclipse开发环境. 步骤: 1.安装JDK(Java Development Kit):JDK包含了java掩饰程序和样例.Java公共API类的源代码.J ...

  10. lua(仿类)

    Account = { balance = } function Account:deposit(v) self.balance = self.balance + v end function Acc ...