我一般捕捉异常的方式如下:

BEGIN

.....

EXCEPTION
  WHEN OTHERS THEN
    ROLLBACK;
    ERR1        := SUBSTR(SQLERRM, 1, 100);
    TOM_SQLCODE := SQLCODE;
    SELECT SYS_CONTEXT('USERENV', 'IP_ADDRESS') INTO TOM_IP FROM DUAL;

END;

在pro*c里面 都会打印sqlcode,可以通过DBMS_OUTPUT.PUT_LINE(sqlerrm(TOM_SQLCODE))将其转换成ora异常。

下面是转载的异常说明

http://space.itpub.net/?uid-24850250-action-viewspace-itemid-688651

为了处理PL/SQL应用程序的各种错误,开发人员可以使用各种类型的异常。

Oracle 提供了
1:预定义异常
用于处理常见的 Oracle 错误
2:非预定义异常
用于处理预定义异常所不能处理的 Oracle 错误
3:自定义异常
用于处理于 Oracle 错误无关的其他情况
异常处理部分是以关键字 EXCEPTION 开始的,语法如下:

  EXCEPTION
    WHEN  exception_NameTHEN  --exception_Name为异常的名字
      statement1;
    WHENOTHERSTHEN
  statement1;
  

异常处理部分从关键字 EXCEPTION 开始,在异常处理部分使用 WHEN 字句捕捉各种异常,如果有其他未预定义到的异常,使用 WHEN OTHERSTHEN 字句进行捕捉和处理。
1、 处理预定义异常,这是系统预定的21种类型

  错误代码是负整数,如-51
  
  Access_info_null(ora-06530)
  
  当访问没有初始化的对象时触发。
  
  Case_not_found(ora-06592)
  
  case过程中when后没有包含必要的条件分支并且没有else子句,则会触发本异常。
  
  Collection_is_null(06531)
  
  访问未初始化的集合元素(嵌套表或者varray)。
  
  Cursor_already_open(ora-06511)
  
  重新打开已经打开的游标。
  
  Dup_val_on_index(ora-00001)
  
  当中唯一索引所对应的列上键入重复值时。
  
  Invalid_cursor(ora-01001)
  
  试图在不合法的游标上执行操作时,譬如没打开游标就提取内容
  
  Invalid_number(ora-01722)
  
  当试图将非法的字符串转换为数字类型时。
  
  No_data_found(ora-01403)
  
  执行select into未返回行,或者引用了索引表未初始化的元素时。
  
  Too_many_rows(ora-01422)
  
  执行select into返回超过一行数据时。
  
  Zero_divide(ora-01476)
  
  0作为被除数时。
  
  Subscript_beyond_count(ora-06533)
  
  使用嵌套表或者varray集合时,如果引用下标超过last。
  
  Subscript_outside_limit(ora-06532)
  
  使用嵌套表或varray集合时,如果引用下标小于first。
  
  Value_error(ora-06502)
  
  在执行赋值操作时,如果变量长度不足以容纳实际数据。
  
  Login_denied(ora-01017)
  
  连接数据库时提供了不正确的用户名或口令。
  
  Not_logged_on(ora-01012)
  
  在程序没有连接到oracle数据库时执行plsql代码则会触发。
  
  Program_error(ora-06501)
  
  plsql内部问题。
  
  Rowtype_mismatch(ora-06504)
  
  执行赋值操作时,如果宿主游标变量和PLSQL游标变量返回类型不兼容时。
  
  Self_is_null(ora-30625)
  
  使用对象类型时,如果在null实例上调用成员方法。
  
  Storage_error(ora-06500)
  
  超出内存空间或者内存被损坏。
  
  Sys_invalid_rowid(ora-01410)
  
  无效字符串企图转换为rowid类型时。
  
  Timeout_on_resource(ora-00051)
  
  等待资源时出现超时错误。
  

2、处理非预定义异常
使用非预定义异常包括三步:
一:在定义部分定义异常名,
二:在异常和 Oracle 错误之间建立关联,
三:在异常处理部分捕捉并处理异常。

当定义 Oracle 错误和异常之间的关联关系时,需要使用伪过程 EXCEPTION_INIT 。

一:首先的定义部分定义异常;
二:使用 progmaexception_init(exception_name,exception_number) 在异常和 oracle 错误之间建立关联,
    这时要求用户知道可能出现的错误号(异常函数 sqlcode 、 sqlerrm 和 raise_application_error );
三:最终在异常处理部分捕捉并处理异常。

下面以更新特定雇员的部门号,并处理 ORA-02291 错误为例,说明使用非预定义异常的方法。示例如下:

  DECLARE
    e_integrity EXCEPTION;  --1、定义部分
    PRAGMA EXCEPTION_INIT(e_integrity,-2291);  --2、建立关联关系
  BEGIN
    UPDATE  empSETdeptno=  &dnoWHERE  empno=&eno;
  EXCEPTION
    WHEN  e_integrityTHEN  --3、捕捉处理
      DBMS_OUTPUT.PUT_LINE(‘该部门不存在’);
  END;

--3、处理自定义异常
预定义异常和非预定义异常都与 Oracle 错误有关,并且当出现 Oracle 错误时会隐含触发相应异常;
而自定义异常与 Oracle 错误没有任何关联,它是由开发人员为特定情况所定义的异常。

当使用自定义异常时,
一:需要在定义部分( DECLARE )定义异常,
二:再执行部分( BEGIN )触发异常(使用 RAISE 语句),
三:在异常处理部分( EXCEPTION )捕捉并处理异常。

  declare
  myexceptionexception;
  begin
  
if
1=0
then
  
raisemyexception;
  
endif;
  exception
  
when

myexception
then
       dbms_output.put_line('asdf');
  end;

注意:不能在同一个 block 中描述 EXCEPTION 两次,但是可以描述一个 exception 在两个不同的 block 中。异常( exception )是有作用域的,子块的异常不能被当前块所捕捉,

--4、使用异常函数:
Oracle 内置函数 sqlcode 和 sqlerrm 主要用在 others 处理器中,分别用来返回 oracle 的错误代码和错误消息。
一般情况下 sqlcode 返回负数标识的 oracle 错误代码,除非错误
为 ‘ora-01403 : no data found’ ,此时对应的 sqlcode 为 +100 ,
对于用户自定义的异常, sqlcode 返回 +1 ,如果没有异常被触发, sqlcode 返回 0 。

  Begin
  Exception
  When  othersthen
      Dbms_output.put_line(sqlcode||sqlerrm(sqlcode));
  End;
  

Oracle 过程 raise_application_error 用于在 plsql 应用程序中自定义错误消息。
注意该过程只能在数据库端的子程序(过程、函数、包、触发器)中使用,而不能在匿名块和客户端的子程序中使用。
语法为 raise_application_error(error_number,message[,[true|false]]);
其中

error_number 用于定义错误号,该错误号必须在 -20000 到 -20999 之间的负整数;
message 用于指定错误消息,并且该消息的长度不
能超过 2048 字节;
第三个参数如果为 true ,则该错误会被放在先前错误堆栈中,如果为 false (默认值)则会替代先前所有错误。

  IFproduct_not_foundTHEN
               RAISE_APPLICATION_ERROR(-20123,'Invald product code'  TRUE);
  ENDIF;
  

--5、plsql编译警告:
plsql 警告可以分为四类:
severe :用于
检查可能出现的不可预料或者错误结果,例如参数的别名问题;
performance :用于检查可能引起的性能问题,例如执行 insert 操作时为 number 列提供了 varchar2 类型数据;
informational :用于检查子程序中的死代码;
all :用于检查所有警告。

为了数据库可以在编
译 plsql 子程序时发出警告信息,需要设置初始化参数 plsql_warnings 。这个参数不仅可以在系统级或者会话级设置,也可以在 alter procedure 命令中设置。

  Alter{system|session|procedure}
  setplsql_warnings=
  
’{enable|disable:{all|performance|severe|informational}}’;
  

为了检查是否存在对应警告信息,必须先激活警告检查,然后重新编译子程序,
最后使用 show errors 命令显示警告错误。

  createor  replaceprocedure  my_test
  is
  begin
  if  1=0then
      dbms_output.put_line('test');
  endif;
  end;
  SQL>  alterprocedure  my_test compile plsql_warnings='enable:all';

Procedurealtered
  SQL>  show errors;
  Errorsfor  PROCEDURESYS.MY_TEST:
  LINE/COL ERROR
  --------  -------------------------
  10/5      PLW-06002:无法执行的代码

--6、定义Exception时要注意的一些事项
当异常发生时,在块的内部没有该异常处理器时,控制将转到或传播到上一层块的异常处理部分。
没有处理的异常将沿检测异常调用程序传播到外层,当异常被处理并解决或到达程序最外层传播停止。在声明部分抛出的异常将控制转到上一层的异常部分。

用户必须在独立的 WHEN 子串中为每个异常设计异常处理代码, WHEN OTHERS 子串必须放置在最后面作为缺省处理器处理没有显式处理的异常。当异常发生时,控制转到异常部分, ORACLE 查找当前异常相应的 WHEN..THEN 语句,捕捉异常, THEN 之后的代码被执行,如果错误陷阱代码只是退出相应的嵌套块,那么程序将继续执行内部块 END 后面的语句。如果没有找到相应的异常陷阱,那么将执行 WHEN OTHERS 。在异常部分 WHEN 子串没有数量限制。

  EXCEPTION
  
WHENinventory_too_lowTHEN
  
      ......
  
WHENdiscontinued_itemTHEN
  
      ......
  
WHENzero_divideTHEN
  
      ......
  
WHENOTHERSTHEN
  
      ......
  

ORACLE SQLCODE相关推荐

  1. oracle sqlcode 多条,SQL查询以连接Oracle中多个行的列值

    是否有可能构造SQL来连接列值 多行? 以下是一个示例: 表A PID A B C 表B PID   SEQ    DESC A     1      Have A     2      a nice ...

  2. code函数oracle列子,Oracle内置函数SQLCODE和SQLERRM的使用

    Oracle内置函数SQLCODE和SQLERRM的使用 Oracle内置函数SQLCODE和SQLERRM是特别用在OTHERS处理器中,分别用来返回Oracle的错误代码和错误消息. OTHERS ...

  3. oracle pl/sql 程序设计 历史笔记整理

    20131016 周三 oracle pl/sql 程序设计 第2章 创建并运行pl/sql代码 sqlplus yjkhecc/yjkhecc@10.85.23.92:1521/orcl 在java ...

  4. Oracle常用傻瓜问题1000问

    1. Oracle安装完成后的初始口令? internal/oracle sys/change_on_install system/manager scott/tiger sysman/oem_tem ...

  5. oracle 插入 基准测试,oracle proc 插入操作性能优化实践

    场景: student 表中 10万条数据. 从 student 表中取出所有数据,插入到 student_his 表中 优化方法: 1.批量插入(效果明显) 2.批量查询(效果不明显) 3.批量提交 ...

  6. Oracle語句大全

    1. Oracle安装完成后的初始口令? internal/oracle sys/change_on_install system/manager scott/tiger sysman/oem_tem ...

  7. Oracle如何代码编辑,配置UltraEdit为Oracle PL/SQL代码编辑器

    配置UltraEdit为Oracle PL/SQL代码编辑器[@more@] 将下文复制到UltraEdit的wordfile.txt的最后,就能实现UltraEdit中对PL/SQL文件语法突出显示 ...

  8. oracle proc 定义宿主,oracle proc 编程基础及最小化案例

    oracle proc 编程是在我的概念中是非常陌生的,学习了一天下来发现这东西真的好古老,但是依然健壮.稳定,其中间是编辑一个 .pc 的文件使用 proc 进行预处理,预处理后生成一个真正的.c文 ...

  9. Oracle Study之--Oracle触发器(Trigger)

    本篇主要内容如下: 8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建触发器 8.2.1 触发器触发次序 8.2.2 创建DML触发器 8.2. ...

最新文章

  1. python csv读取-python如何读取csv数据
  2. 简单易懂的现代魔法——Play Framework攻略4
  3. 超图使用服务管理页面发布服务图解
  4. 文巾解题 231. 2的幂
  5. caffe windows学习:第一个测试程序
  6. spring手动配置
  7. HBase读链路分析
  8. python制作简单网页_python 跑服务器,访问自己制作的简单页面
  9. 【参与开源】J2EE开源项目JEECG快速开发平台,欢迎广大技术爱好者参与,第三期招募新成员
  10. Typescript 学习笔记一:介绍、安装、编译
  11. 数据安全对企业的重要性
  12. 今天用pro安装nginx+php+mysql出现故障的解决方法
  13. emmet工具使用和技巧
  14. DOIT多易教育简介
  15. NS3 Tracing System详解
  16. dirent--文件以及文件夹相关操作(跨平台)
  17. 这些孩子对计算机游戏上瘾英语,沉迷网络游戏高中英语作文
  18. python充分理解def语句
  19. backward()函数中的参数解析
  20. 2022年6月编程语言排行,第一名居然是它?!

热门文章

  1. Javaweb目前的未来学习方向
  2. postgresql ident验证机制的实现
  3. 智能合约链码开发和部署
  4. LWN:9月份LPC上关于folio的一次讨论!
  5. 万字长文轻松彻底入门Flutter,震撼来袭免费下载!
  6. POOM(Pocket Outlook Object Model)开发介绍及应用
  7. 全球居然还有 2 亿多 IPv4 地址未分配
  8. 阿里巴巴图标库,分享各位
  9. 【ORACLE 】ORACLE OCP 071考点记录01
  10. 地址如何维护在配置文件中