引言

    很多时候,我们调用oracle存储过程都会发生各种各样的异常信息,例如ORA-12899值过大,ORA-01400不能插入空值等.虽然说这类异常是前端没控制到位的缘故,但是现实很难100%完全控制住,所以一旦发生了这类异常,并返回的前端显示时就会造成很差的用户体验了.或许,我们可以将这类异常加工一下,包装得好看些,让用户看得懂发生了什么事情,能够自行处理.下面是我的一点尝试.

    我们通常会在oracle存储过程的异常处理得到异常信息,如:

Exception
When Others Then
rollback;
dbms_output.put_line(sqlerrm);
Raise_Application_Error(-20000,sqlerrm);

然而,我们将会得到下面的异常信息,如

ORA-12899: 列 "NIS"."T_CZL_ACCOUNT"."VC_ACCOUNT" 的值太大 (实际值: 35, 最大值: 20)

虽然说我们99%的程序员都看得懂这个是什么意思,但是也有99%的用户看不出个所以然.我们的目标是意外发生了,用户依然看得懂.接下来,我需要创建一个函数,专门处理这类的异常,返回大部分用户看得懂的信息.函数代码如下:

create or replace function f_czl_geterror(message in varchar2)
return varchar2 is
Result varchar2(1000); num1 number:=0;
num2 number:=0;
num3 number:=0;
num4 number:=0;
num5 number:=0;
num6 number:=0;
num7 number:=0;
num8 number:=0;
num9 number:=0;
num10 number:=0;
str1 varchar2(1000);
str2 varchar2(1000);
str3 varchar2(1000);
str4 varchar2(1000);
str5 varchar2(1000);
str6 varchar2(1000);
str7 varchar2(1000);
str8 varchar2(1000);
str9 varchar2(1000);
str10 varchar2(1000);
begin if instr(message, 'ORA-12899')>0 then
num1:=instr(message,'ORA-12899'); --得到 ORA-12899的所在位置
str1:=substr(message,num1); --得到ORA-12899后面的所有字符
num2:=instr(str1,'"',1,3); --得到ORA-12899后面第三个"的位置
num3:=instr(str1,'"',1,4); --得到ORA-12899后面第四个"的位置
str2:=substr(str1,num2+1,num3-num2-1); --得到表名
num4:=instr(str1,'"',1,5); --得到ORA-12899后面第五个"的位置
num5:=instr(str1,'"',1,6); --得到ORA-12899后面第六个"的位置
str3:=substr(str1,num4+1,num5-num4-1); --得到字段名 num6:=instr(str1,':',1,2); --得到ORA-12899后面第二个:的位置
num7:=instr(str1,',',1,1); --得到ORA-12899后面第1个,的位置
str5:=substr(str1,num6+1,num7-num6-1); --得到输入的长度 num8:=instr(str1,':',1,3); --得到ORA-12899后面第二个:的位置
num9:=instr(str1,')',1,1); --得到ORA-12899后面第1个,的位置
str6:=substr(str1,num8+1,num9-num8-1); --得到最大的长度 --得到对应的字段注释
select t.comments into str4 from SYS.USER_COL_COMMENTS t where t.column_name=str3 and t.table_name=str2; Result:=str4||'长度超出限制,最大字符数为'||str6||',您输入的字符数为'||str5||'.';
elsif instr(message, 'ORA-01400')>0 then num1:=instr(message,'ORA-01400'); --得到 ORA-01400的所在位置
str1:=substr(message,num1); --得到ORA-01400后面的所有字符
num2:=instr(str1,'"',1,3); --得到ORA-01400后面第三个"的位置
num3:=instr(str1,'"',1,4); --得到ORA-01400后面第四个"的位置
str2:=substr(str1,num2+1,num3-num2-1); --得到表名
num4:=instr(str1,'"',1,5); --得到ORA-01400后面第五个"的位置
num5:=instr(str1,'"',1,6); --得到ORA-01400后面第六个"的位置
str3:=substr(str1,num4+1,num5-num4-1); --得到字段名 --得到对应的字段注释
select t.comments into str4 from SYS.USER_COL_COMMENTS t where t.column_name=str3 and t.table_name=str2; Result:=str4||'不能为空,请输入内容.';
elsif instr(message, 'ORA-01438')>0 then Result:=str4||'数字长度超出限制,请检查!';
else Result:=message;
end if; return(Result);
end f_czl_geterror;

然后我们在存储过程的异常处理中用上这个函数,如:

Exception
When Others Then
rollback;
dbms_output.put_line(f_czl_geterror(sqlerrm));
Raise_Application_Error(-20000,f_czl_geterror(sqlerrm));

再测试看看,我们得到了:

账号长度超出限制,最大字符数为 20,您输入的字符数为 35.

起码有的用户看得懂了是吧,咱们的目标算是达成了.

小结

  上文介绍了如何将oracle的系统异常信息转换成用户看得懂的信息.其实这只是一种补救的措施罢了,某种程度上是'欺骗'了用户,程序是正常运行的,但是不能否认的是我们的程序依然不完善.但是,有的补救好过没有是吧.最后,如果您有更好的建议,请不吝指教.

【Oracle】异常信息的加工处理的更多相关文章

  1. oracle存储过程获取异常信息码和异常信息

    oracle存储过程,可以通过sqlcode 获取异常编码.通过sqlerrm获取异常信息. 例子: create or replace procedure write2blob(p_id in nu ...

  2. oracle 异常

    ORACLE 异常错误处理 本篇主要内容如下: 5.1 异常处理概念 5.1.1 预定义的异常处理 5.1.2 非预定义的异常处理 5.1.3 用户自定义的异常处理 5.1.4  用户定义的异常处理 ...

  3. 也谈Oracle异常: ORA-06502: PL/SQL: 数字或值错误 : 字符串缓冲区太小

    场景: .Net程序调用Oracle方法 command.ExecuteNonQuery()执行存储过程;弹出如标题异常信息. 存储过程有4个输入参数,一个输出参数.一旦执行到给输出参数赋值的时候就报 ...

  4. [转]ORACLE 异常错误处理

    本文转自:http://www.cnblogs.com/soundcode/archive/2012/01/10/2318385.html 本篇主要内容如下: 5.1 异常处理概念 5.1.1 预定义 ...

  5. 总结:整理 oracle异常错误处理 .

    5.1 异常处理概念 5.1.1 预定义的异常处理 5.1.2 非预定义的异常处理 5.1.3 用户自定义的异常处理 5.1.4  用户定义的异常处理 5.2 异常错误传播 5.2.1 在执行部分引发 ...

  6. Oracle异常汇总

    持续更新中,可参见https://hnuhell.gitbooks.io/oracle_errmg/content/或https://hnuhell.github.io/Oracle_ERRMG/上的 ...

  7. 整理 oracle异常错误处理

    5.1 异常处理概念 5.1.1 预定义的异常处理 5.1.2 非预定义的异常处理 5.1.3 用户自定义的异常处理 5.1.4  用户定义的异常处理 5.2 异常错误传播 5.2.1 在执行部分引发 ...

  8. oracle 异常错误处理

    分类: Oracle 5.1 异常处理概念 5.1.1 预定义的异常处理 5.1.2 非预定义的异常处理 5.1.3 用户自定义的异常处理 5.1.4 用户定义的异常处理 5.2 异常错误传播 5.2 ...

  9. 异常信息:javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed

    上周五遇到一个问题,工程本地编译运行正常,打包本地tomcat运行也正常.部署到测试环境报错: 2017-05-05 09:38:11.645 ERROR [HttpPoolClientsUtil.j ...

随机推荐

  1. (2)linux未使用eth0,未使用IPV4导致无法连接

    首先ifconfig查看网络IP 看,我这里默认启用了2个网卡,一个是eth0,另一个是lo(基于loopback方式) 1.如果有eth0则做:界面修改 (1)输入命令setup,选择network ...

  2. ELBO 与 KL散度

    浅谈KL散度 一.第一种理解 相对熵(relative entropy)又称为KL散度(Kullback–Leibler divergence,简称KLD),信息散度(information dive ...

  3. Windows 上将Tomcat 8 安装为系统服务

    第一部分 应用场景 需要服务器上Tomcat不显示启动窗口 需要服务器上Tomcat开机自启动 ... 第二部分 配置过程 一.修改配置文件 1 {Tomcat_HOME}/bin/service.b ...

  4. 交换机/路由器上的 S口 F口 E口

    S口是serial接口的意思,也叫高速异步串口,主要是连接广域网的V.35线缆用的,说白了就是路由器和路由器连接时候用的,可以用命令设置带宽,一般也就在10M.8M左右.F口是FastEthernet ...

  5. iOS self 和 super 学习

    有人问我 这个问题 回答错了,题干大概是说 [self class] 和 [super class]打印结果 是不是一样的. 我睁着眼睛说是不一样的 .因为我明明记得 几天前 做 DFS 获取反射基类 ...

  6. 函数---迭代器&生成器&列表解析&三元表达式

    可迭代对象:obj.__iter__   迭代器:iter1=obj.__iter() 1iter1.__next__ 2iter2.__next__   迭代器: 优点:不依赖索引         ...

  7. Shell编程之Linux信号及信号跟踪

    一.Linux信号 1.什么是信号? Linux信号是由一个整数构成的异步消息,它可以由某个进程发给其他进程,也可以在用户按下特定键发生某种异常事件时,由系统发给某个进程. 2.信号列表 [root@ ...

  8. MySQL数据库基本操作(二)

    表结构操作 ( ALTER TABLE) 添加单列: ALTER TABLE tb1_name ADD [COLUNM] col_name column_definition [FIRST|AFTER ...

  9. 13.常见模块re-正则模块

    1.正则 正则表达式是计算机科学的一个概念,正则表通常被用来检索.替换那些符合某个模式(规则)的文本.也就是说使用正则表达式可以在字符串中匹配出你需要的字符或者字符串,甚至可以替换你不需要的字符或者字 ...

  10. SQLite3时间函数小结

    import sqlite3 conn = sqlite3.connect('/tmp/sqlite.db') cur = conn.cursor() 接下来干嘛呢?建一张表吧.这里需要注意的是,SQ ...