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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/419856.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

文件已经上传到服务器翻译,服务器接受上传的优化 翻译+源码分析

一般的做法err : r.ParseMultipartForm(32 << 20) // 32Mbif err ! nil {http.Error(w, err.Error(), http.StatusBadRequest)}问题请注意&#xff0c;32Mb是分配给请求体的字节存储在内存中&#xff0c;而不是请求体的限制&#xff0c;当满(33Mb)时&#xff0c;它将写入…

隐藏a标签seo_让黑帽都惊了,远离百度惩处的seo技术

一、什么是黑帽SEO黑帽SEO&#xff0c;即SEO作弊&#xff0c;是指为了提高网站在搜索引擎中展现机会和排名的目的&#xff0c;欺骗搜索引擎的行为“黑帽”技术与搜索引擎算法相排斥&#xff0c;是搜索引擎不允许的。一旦被发现使用“黑帽”技术&#xff0c;那么网站排名会被降低…

前端学习(1501):一次帮别人解决问题的案例

超开心 只能添加姓名 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> </…

PHP的time函数返回时间不正确

PHP的time()得到的时间与当前时间相差很多&#xff0c;检查了PHP.ini&#xff0c;发现是时区不对。在PHP.ini中&#xff0c;当前设置为&#xff1a; [Date]; Defines the default timezone used by the date functions; http://php.net/date.timezonedate.timezone Europe/Par…

微信小程序服务器sessionid,微信小程序sessionid不一致问题解决

微信小程序sessionid不一致问题解决,里加,两次,在后面,解决办法,缓存微信小程序sessionid不一致问题解决易采站长站&#xff0c;站长之家为您整理了微信小程序sessionid不一致问题解决的相关内容。问题由于小程序端两次请求的 sessionid 不一致&#xff0c; 导致后端无法取得 s…

mysql 加字段_MySQL8.0大表秒加字段,是真的吗?

前言&#xff1a;很早就听说 MySQL8.0 支持快速加列&#xff0c;可以实现大表秒级加字段。笔者自己本地也有8.0环境&#xff0c;但一直未进行测试。本篇文章我们就一起来看下 MySQL8.0 快速加列到底要如何操作。1.了解背景信息表结构的变更是业务运行过程中比较常见的需求之一&…

SQLServer学习笔记系列4

一.写在前面的话 好多天没有记录sql学习笔记了&#xff0c;要坚持下去&#xff0c;坚信每一点的进步都是为在积蓄力量。今天看到一幅图&#xff0c;特此分享出来。 通过这幅图&#xff0c;我看到的是每人站在自己的角度看问题&#xff0c;感受是不一样的&#xff0c;就如同学习…

随便选一张扑克牌_扑克牌魔术手法教学,简单易学的纸牌魔术,三分钟让你成为大师...

标签&#xff1a; 魔术手法 扑克牌魔术 魔术技巧教学 纸牌魔术揭秘所有的纸牌魔术家都知道怎样假装把一张牌塞进牌堆&#xff0c;然后从顶部翻出来来让观众吃惊。这个技巧用来练习手速、手指灵敏度、适时分散观众注意力和表演艺术绝对是不可或缺。这里就给大家介绍一下吧&#…

JAVA求集合中的组合

好几个月没弄代码了&#xff0c;今天弄个求组合的DEMO 思路是将集合的每个值对照一个索引&#xff0c;索引大小是集合的大小2.索引默认为[000...000]&#xff0c;当组合后选取的组合值demo为[0100..00]。然后根据遍历索引来到集合中取值。 上代码&#xff1a; import java.util…

mysql使用手册_mysql使用手册

mysql使用手册1、mysql登录1.1 远程登陆mysqlmysql -h ip -u root -p 密码1.2 本地登陆mysqlmysql -u root -p 密码2、为数据库配置远程连接权限采用授权法例如&#xff1a;以用户名&#xff1a;root 密码&#xff1a;888888从任何主机连接到mysql服务器先在服务器上用root用户…

Android项目使用Eclipse进行单元测试

Android项目如果每次都整个调试的话&#xff0c;要加载UI&#xff0c;会等很长时间。所以单元测试就显得很方便了。 要进行单元测试&#xff0c;首先得修改下AndroidManifest.xml文件。在Instrument标签里点右侧的Add按钮。然后在弹出的窗口双击 Instrument。然后在右侧就会多出…

mysql union 用法 update_mysql---union的用法

union的作用很简单用来合并两条sql的结果集语法: SQL1 UNION SQL2现有一张价格表要求&#xff1a;求出价格低于2000和价格高于3000的商品&#xff0c;不能用or和not between……and思路&#xff1a;我们可以先求出低于2000的商品得到结果集1再求出高于3000的商品得到结果集2再利…

mysql 中有没有临时表_MySQL临时表的简单用法

当工作在非常大的表上时,你可能偶尔需要运行很多查询获得一个大量数据的小的子集,不是对整个表运行这些查询,而是让MySQL每次找出所需的少数记录,将记录选择到一个临时表可能更快些,然后在这些表运行查询。创建临时表很容易,给正常的CREATE TABLE语句加上TEMPORARY关键字:CREAT…

java中==与equals的区别

值类型是存储在内存中的堆栈&#xff08;以后简称栈&#xff09;&#xff0c;而引用类型的变量在栈中仅仅是存储引用类型变量的地址&#xff0c;而其本身则存储在堆中。 操作比较的是两个变量的值是否相等&#xff0c;对于引用型变量表示的是两个变量在堆中存储的地址是否相同&…

3399 mysql_手动安装 mysql

手动安装 mysql需要在本机 (mac) 上装个 mysql, 看到压缩版的体积最小, 结果进入了手工安装的坑(正常有界面可以安装, 但安装目录将是 / usr/local/mysql), 既然入了坑就填上吧.1, 解压到自己选择的目录, 比如 / data/mysql.2, 初始化数据库: sudo /data/mysql/bin/mysqld --in…

构建之法第11、12章

第11章软件设计与实现 主要讲了典型的开发流程和开发阶段的一些管理方法 问题&#xff1a; 从spec道实现是代码的实现吗&#xff1f; 第12章 用户体验 主要讲了用户体验的各种角度和认识阻力登 问题&#xff1a; 用户的体验是设计前就要考虑的吗&#xff1f;转载于:https://www…

Mybatis多对多,复杂增删改查(特殊需求循环插入,分组查询)

2021.8.31 从25号开始练习复杂的mybatis多对多&#xff0c;从设计数据库思路到实现需求功能转移到实体项目中 1.之前很少看过字符转换的详细内容从今往后会注意字符串转换此项目为转数组&#xff08;date&#xff09;实体项目会有UUID生成的字符串 2.在添加时如果原表设计的首个…

MDI窗体简单方法(调用,闪屏)

MDI窗体简单方法&#xff08;调用,闪屏&#xff09; 调用方式&#xff1a; RibbonForm mdishow new RibbonForm(); //实例化midshow.MdiParent this; //设置在主窗体&#xff0c;以MDI的方式显示&#xff0c;关键属性。mdishou.Show();//显示窗体大伙都会碰到的问题。 解决…