ORACLE中的异常处理
异常的语法格式
在begin语句内:
exception
when then
when then
when others then
--异常处理
--首先创建一份对象的用法
create type xtype as object (name varchar2(20));
declare
x xtype;
begin
x.name:='aaa';
exception
when ACCESS_INTO_NULL then
dbms_output.put_line('init x first');
end;
--不报错了 变成了一种正常的行为
--case not found
declare
x number(9);
begin
x:=&x;
case
when x>100 then
dbms_output.put_line('>100');
when x>200 then
dbms_output.put_line('>200');
end case;
exception
when CASE_NOT_FOUND then
dbms_output.put_line('case not found');
end;
oracle在预定义包STANDARD包中提供了一系列的预定义异常。他们是调试Oracle PL/SQL程序的有用工具。大部分错误用负号作为错误号。可以使用SQLCODE内置函数看到错误代码,使用SQLERRM得到异常的内置消息。
|
异常 |
错误 |
何时出现 |
|
ACCESS_INTO_NULL |
ORA-06530 |
试图访问未初始化对象的时候出现 |
|
CASE_NOT_FOUND |
ORA-06592 |
如果定义了一个没有ELSE子句的CASE语句,而且没有CASE语句满足运行时条件时出现该异常 |
|
COLLECTION_IS_NULL |
ORA-06531 |
当程序去访问一个没有进行初始化的NESTED TABLE或者是VARRAY的时候,会出现该异常 |
|
CURSOR_ALREADY_OPEN |
ORA-06511 |
游标已经被OPEN,如果再次尝试打开该游标的时候,会出现该异常 |
|
DUP_VAL_ON_INDEX |
ORA-00001 |
如果插入一列被唯一索引约束的重复值的时候,就会引发该异常(该值被INDEX认定为冲突的) |
|
INVALID_CURSOR |
ORA-01001 |
不允许的游标操作,比如关闭一个已经被关闭的游标,就会引发 |
|
INVALID_NUMBER |
ORA-01722 |
给数字值赋非数字值的时候,该异常就会发生,这个异常也会发生在批读取时候LIMIT子句返回非正数的时候 |
|
LOGIN_DENIED |
ORA-01017 |
程序中,使用错误的用户名和密码登录的时候,就会抛出这个异常 |
|
NO_DATA_FOUND |
ORA_06548 |
在使用SELECT INTO 结构,并且语句返回NULL值的时候;访问嵌套表中已经删除的表或者是访问INDEX BY表(联合数组)中的未初始化元素就会出现该异常 |
|
NOT_LOGGED_ON |
ORA-01012 |
当程序发出数据库调用,但是没有连接的时候(通常,在实际与会话断开连接之后) |
|
PROGRAM_ERROR |
ORA-06501 |
当Oracle还未正式捕获的错误发生时常会发生,这是因为数据库大量的Object功能而发生 |
|
ROWTYPE_MISMATCH |
ORA-06504 |
如果游标结构不适合PL/SQL游标变量或者是实际的游标参数不同于游标形参的时候发生该异常 |
|
SELF_IS_NULL |
ORA-30625 |
调用一个对象类型非静态成员方法(其中没有初始化对象类型实例)的时候发生该异常 |
|
STORAGE_ERROR |
ORA-06500 |
当内存不够分配SGA的足够配额或者是被破坏的时候,引发该异常 |
|
SUBSCRIPT_BEYOND_COUNT |
ORA-06533 |
当分配给NESTED TABLE或者VARRAY的空间小于使用的下标的时候,发生该异常(类似于java的ArrayIndexOutOfBoundsException) |
|
SUBSCRIPT_OUTSIDE_LIMIT |
ORA-06532 |
使用非法的索引值来访问NESTED TABLE或者VARRAY的时候引发 |
|
SYS_INVALID_ROWID |
ORA-01410 |
将无效的字符串转化为ROWID的时候引发 |
|
TIMEOUT_ON_RESOURCE |
ORA-00051 |
当数据库不能安全锁定资源的时候引发 |
|
TOO_MANY_ROWS |
ORA-01422 |
常见错误,在使用SELECT INTO 并且查询返回多个行时引发。如果子查询返回多行,而比较运算符为相等的时候也会引发该异常。 |
|
USERENV_COMMITSCN_ERROR |
ORA-01725 |
只可使用函数USERENV('COMMITSCN')作为INSERT语句的VALUES子句中的顶级表达式或者作为UPDATE语句的SET子句中的右操作数 |
|
VALUE_ERROR |
ORA-06502 |
将一个变量赋给另一个不能容纳该变量的变量时引发 |
|
ZERO_DIVIDE |
ORA-01476 |
将某个数字除以0的时候,会发生该异常 |
可以很方便的在SQL块中使用EXCEPTION来捕捉异常并且进行处理(当然,编译异常与在声明块中被抛出的异常除外,一个好的PL/SQL编程 习惯是规避在声明块中进行变量的赋值操作)。如果上面的预定义异常能够满足要求,就可以使用他们。如果不满足,则可以像JAVA程序一样,定义自己的异 常,并且可以使用RAISE EXCEPTION来抛出异常。
--pl/sql自定义的异常 比如更新数据时并没有找到数据没有数据进行改变
select * from myemp;
declare
emp_nofound_exception exception;
begin
update myemp set sal=sal+2 where empno=&empno;--如果输入的输一个字符串的话 就要用单引号括起来
if sql%notfound then
raise emp_nofound_exception;
else
dbms_output.put_line('ok');
end if;
exception
when emp_nofound_exception then
dbms_output.put_line('no emp found!');
when others then
dbms_output.put_line('others');
end;
--使用两个函数
--sqlcode sqlerrm
declare
emp_nofound_exception exception;
begin
update myemp set sal=sal+2 where empno=&empno;--如果输入的输一个字符串的话 就要用单引号括起来
if sql%notfound then
raise emp_nofound_exception;
else
dbms_output.put_line('ok');
end if;
exception
when others then
dbms_output.put_line('sqlcode='||sqlcode);
dbms_output.put_line('sqlerrm='||sqlerrm);--如果错误信息很长的话 可以用substr(sqlerrm,1,100)切割成一百的字符串
end;
ORACLE中的异常处理的更多相关文章
- oracle中的异常处理方法
异常处理create or replace procedure prc_get_sex (stuname student.name%type) as stusex student.sex%type; ...
- Oracle中PL/SQL的执行部分和各种流程控制
Oracle中PL/SQL的执行部分和异常部分 一.PL/SQL的执行部分. 赋值语句. 赋值语句分两种,一种是定义一个变量,然后接收用户的IO赋值:另一种是通过SQL查询结果赋值. 用户赋值举例: ...
- Oracle中PL/SQL简介、基本语法以及数据类型
Oracle中PL/SQL简介.基本语法以及数据类型 一.PL/SQL简介. Oracle PL/SQL语言(Procedural Language/SQL)是结合了结构化查询和Oracle自身过程控 ...
- Oracle PL/SQL 异常处理
Oracle数据库中的异常:没有异常的转移,因为没有受检异常和非受检异常得区分. 1.异常的产生: 2.异常的处理: declare --变量定义,初始化赋值. begin --变量的赋值,函数调用, ...
- Oracle中的游标(转)
Oracle中的游标有两种:显式游标.隐式游标.显示游标是用cursor...is命令定义的游标,它可以对查询语句(select)返回的多条记录进行处理,而隐式游标是在执行插入 (insert).删除 ...
- Oracle中RAISE异常
转: Oracle中RAISE异常 由三种方式抛出异常 1. 通过PL/SQL运行时引擎 2. 使用RAISE语句 3. 调用RAISE_APPLICATION_ERROR存储过程 当数据库或PL/S ...
- oracle中的创建过程,函数,包
一.创建存储过程 存储过程是在oracle中存取完成特定业务逻辑的代码块.存储过程是命名块,匿名块不存在数据库中,命名块会存储到数据库中,匿名块每次运行都需要提前编译,命名块一次存储,只会编译一次.命 ...
- 【repost】JS中的异常处理方法分享
我们在编写js过程中,难免会遇到一些代码错误问题,需要找出来,有些时候怕因为js问题导致用户体验差,这里给出一些解决方法 js容错语句,就是js出错也不提示错误(防止浏览器右下角有个黄色的三角符号,要 ...
- Oracle中varchar,varchar2,nvarchar,nvarchar2的区别及其它数据类型描述
--varchar,varchar2 联系: 1.varchar/varchar2用于存储可变长度的字符串 比如varchar(20),存入字符串'abc',则数据库中该字段只占3个字节,而不是20个 ...
随机推荐
- 火狐下不能使用非行间样式currentStyle用getComputedStyle获取
用js的style属性可以获得html标签的样式,但是不能获取非行间样式.那么怎么用js获取css的非行间样式呢?在IE下可以用currentStyle,而在火狐下面我们需要用到getComputed ...
- plsql developer连接oracle 12.2报错 ora-28040 No matching authentication protocol
使用plsql连接时,发现报ora-28040 No matching authentication protocol 赶紧查了查MOS,原来在默认情况下Oracle12.2对客户端版本有限制, 解决 ...
- 菜鸟成长心酸史之php初遇教程
phpstorm是我接触到的第二个制作网页的程序,刚拿到php的时候,我是懵逼的,从安装到使用,可以说一点都不会,尤其是它还要配合wampsever使用,即使看视频,不同的制作php的软件也有不同的地 ...
- C语言实现随机数
最近在看<The C Programming Language>这本书,看到一个关于随机数的知识点,有种豁然开朗的感觉.以前总靠死记硬背,也不明白为啥是这样,而且总把srand()遗漏.相 ...
- 泰坦尼克(Titanic)生存因素可视化
数据来源: kaggle 分析工具:Python 3.6 & jupyter notebook 附上数据:链接: https://pan.baidu.com/s/1D7JNvHmqTIw0Oo ...
- 用NI的数据采集卡实现简单电子测试之5——压控振荡器的测试
本文从本人的163博客搬迁至此. 为了展示连续信号采集的方法,以其外部触发采集功能.我用运算放大器实现了一个最简单的低频压控振荡器(VCO),作为USB-6009采集的信号源.在LabVIEW下编写的 ...
- 【AHOI2012】信号塔
题面 题解 xgzc怒切计算几何 最小圆覆盖板子题 整体算法如下: 枚举第一个点,考虑当前圆是否包含了这个点,如果没有,则把圆变成以这个点为圆心,半径为\(0\)的圆.再枚举第二个点,考虑圆是否包含了 ...
- 4008: [HNOI2015]亚瑟王
4008: [HNOI2015]亚瑟王 链接 分析: 根据期望的线性性,直接求出每张牌出现的概率,最后乘以攻击力就是答案. 每张牌出现的概率只与它前面的牌有关,与后面的没有关系,于是按顺序考虑每张牌. ...
- 团队合作开发git冲突解决方案 Intellij IDEA
https://blog.csdn.net/antony9118/article/details/52524873 注:因为我使用的是 idea 2018.1.2的版本,所以在操作上有些变化 将某些操 ...
- JAVAWEB和数据库 Mysql连接不上的原因及解决方案
有可能是安装了phpstudy或者wampserver这类自带mysql的web集成环境, 在关闭集成环境时误关了相对应的mysql服务,所以我们需要手动启动服务. 启动mysql的命令: net s ...