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;
转载于:https://www.cnblogs.com/chengzhipcx/p/4559957.html
ORACLE中的异常处理相关推荐
- oracle解密des乱码,Oracle中des等算法的加解密
1.oracle中加密function CREATE OR REPLACE FUNCTION ENCRYPT_FUNCTION( V_STR VARCHAR2, V_KEY VARCHAR2) RET ...
- 在Oracle中不通过存储过程一次执行多条SQL语句Oracle PL/SQL
PL/SQL是ORACLE对标准数据库语言的扩展,ORACLE公司已经将PL/SQL整合到ORACLE 服务器和其他工具中了,近几年中更多的开发人员和DBA开始使用PL/SQL,本文将讲述PL/SQL ...
- mysql游标遍历中sql语句出现异常_MySQL中的异常处理,游标
一.异常处理的理解 ERROR 1062 (23000): Duplicate entry '2' for key 'PRIMARY' 错误 4位error code(5位sql statis):错误 ...
- oracle 中触发器的作用是什么,oracle创建触发器及作用举例
--创建触发器及作用举例 create or replace trigger tri before delete on emp --在删除emp表数据之前需要做的事根据自己的业务去写,before是在 ...
- 在oracle中要谨慎使用when others then(二)
1.在oracle中when others then会吃掉所有的exception,一般不要使用,否则会掩盖软件的错误提示. 2.应使用精准异常捕获. 如果只是判断查不到数据时的处理,应该用when ...
- Oracle中游标Cursor基本用法详解
这篇文章主要介绍了Oracle中游标Cursor基本用法详解,还是比较全面的,具有一定参考价值,需要的朋友可以了解下. 查询 SELECT语句用于从数据库中查询数据,当在PL/SQL中使用SELECT ...
- Oracle中raise触发异常,Oracle中RAISE异常的解决方法
今天小编给大家分享一篇中RAISE异常的解决方法,感兴趣的朋友跟小编一起来了解一下吧! 有三种方式抛出异常 1.通过PL/SQL运行时引擎 2.使用RAISE语句 3.调用RAISE_APPLICAT ...
- oracle 存储过程 状态,查看ORACLE中正在运行的存储过程 | 学步园
1.如何查看ORACLE中正在运行的存储过程 select owner,name from v$db_object_cache where type like '%PROCE%' and locks ...
- oracle自增列问题i,关于oracle中自增列问题
昨天去面试,面试官文oracle中有没有自增列,平时没留意,今天查了一下资料,做了个例子. oracle中没有自增列,可以设定, 但手写方法.序列或触发器都可以实现,下面是我实现的一种方法 ----- ...
最新文章
- html 辅助标签,工作总结 @Html 辅助方法 为 生成的 标签设置元素属性 htmlAttributes 一个对象,其中包含要为该元素设置的 HTML 特性。...
- 【Netty】NIO 缓冲区 ( Buffer ) 组件
- centos7 mysql二进制_centos7+mysql5.7二进制安装
- php post请求 下载文件,POST请求 下载文件
- 管理者每天要做的十件事
- 动态sql防止报错的写法 当判断语句都是null时候会报错 需要手动添加一个判断语句 一般id都会存在...
- 萤火虫小程序_漫展广州丨第24届酷狗蘑菇萤火虫漫展圆满收官,我们国庆见!...
- Java后台+微信小程序实现推送 “服务通知”
- 数学三角形的所有定理!所有!
- (6.6)【PC中数据隐藏】Linux中隐写:TrueCrypt创建隐藏卷、使用方法
- 关键对话(如何高效沟通)读书总结
- Plugin JavaDoc was not installed: Cannot download 'https://plugins.jetbrains.com/pluginManager/?acti
- android 禁用触摸屏,如何在Android手机中禁用触摸屏?
- 弥散磁共振影像处理的黎曼 芬斯勒几何方法研究
- Android 开发基于 Jenkins 实现持续集成
- Gradient_patch_recovery, Z_Z posteriori error estimator
- K8S:Volume
- 微型计算机与接口技术答案,微机原理及接口技术-习题答案
- java hibernate 是什么意思_Java开源项目Hibernate意义是什么?
- 用python和flask框架写MongoDB数据库网页(通院大三软件设计)运营商信息管理系统(1)环境配置
热门文章
- [vim]在vim中格式化xml
- pro*C/C++支持c++开发实例
- Android开发如何使用JNA
- [react] 有用过react的Fragment吗?它的运用场景是什么
- React开发(224):ant design label绑定值
- React开发(213):React在 DevTools 中显示自定义名称
- 前端学习(3342):ant design中grid排版使用
- 前端学习(1958)vue之电商管理系统电商系统之参数管理
- 前端学习(1620):前端系列实战课程之提取行间样式
- 前端学习(1264):fetch响应结果