引言

    很多时候,我们调用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. ELBO 与 KL散度

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

  2. 使用 C#的 is 和 as 操作符来转型

    在 C#语言中进行类型转换的另一种方式是使用 is 操作符. is 检查一个对象是否兼容于指定的类型,并返回一个 Boolean 值: true 或 false.注意 is 操作符永远不会抛出异常,以 ...

  3. 寻找最大(小)的K个数

    <<编程之美>>一书中提到了寻找最大的K个数的问题,问题可以简单描述为:在长度为N的数组中,寻找第K(K<N)个最大的数.问题的解法涉及到了很多排序算法,对我们理解和运用 ...

  4. iOS 绘制漂亮的折线图

    效果图是这样的: 关键是在 基本策略 是描点 和 连线. 折线基础版本,我找到网上的第三方,UUChart . 特点是朴素,简单,扩展性强. 效果图重点是在折线要有阴影,于是 重点 放在 折线发散的阴 ...

  5. UI控件之UIImageView

    UIImageView:图像视图,用于在应用程序中显示图片 UIImage:是将图片文件转换为程序中的图片对象 UIImageView是UIImage的载体 方法一:用此方法创建图片对象,会将图片ca ...

  6. <script>放在head内和body内有什么区别

    加载的顺序不一样,你可以把HTML看成从上往下加载的. 例如在网速慢的情况下把js代码放在body底部用户会先看到网页结构,等js加载完成后才出现特效 区别简述: 在HTML body部分中的Java ...

  7. python的语法错误总结

    1.keyerror一般是你使用字典里不存在的key产生的错误. 2.TypeError一般是使用的数据类型不符合要求 join函数要求a都是string

  8. Windows10提示“没有权限使用网络资源”的解决方案

    1.点击“开始→运行”,在“运行”对话框中输入“GPEDIT.MSC”,打开组策略编辑器 2.依次选择“计算机配置→Windows设置→安全设置→本地策略→用户权利分配” 3.双击“拒绝从网络访问这台 ...

  9. Pandas的 loc iloc ix 区别

    先看代码: In [46]: import pandas as pd In [47]: data = [[1,2,3],[4,5,6]] In [48]: index = [0,1] In [49]: ...

  10. Windows系统 本地文件如何复制到远程服务器

    很多人在使用远程服务器的时候往往要将本地的文件传输到远程服务器内,方法有很多种,下面介绍下如何使用Windows自带的远程桌面连接程序将文件复制到远程服务器内. 1.首先,点击windows开始按钮, ...