为了账号安全,请及时绑定邮箱和手机立即绑定

Oracle自定义异常的使用

标签:
Oracle


      最近在进行项目开发时,根据业务逻辑在处理数据时,需要返回Message并阻止程序继续运行。但是,在存储过程使用Oracle的Raise根本无法满足要求。

     于是用到了RAISE_APPLICATION_ERROR

     RAISE_APPLICATION_ERROR ( error_number_in IN NUMBER, error_msg_in IN VARCHAR2);

      error_number: 自定义的错误编号。

      error_msg:自定义的错误内容。

     在使用过程中,遇到了下面的问题。

ORA-21000: error number argument to raise_application_error of [xxxx] is out of range

出现这个错误的原因是:在存储过程中定义的错误代码Number不在Oracle所允许的范围之内。

      Oracle允许自定义的错误代码的范围为-20000 -- -20999

      这样,就在Java端可以通过SQLException来捕获异常。

      虽然通过SQLException.getMessage()可以捕获到异常的内容,但是这些内容对于开发比较有用。对于客户来说,并不友好,也没有多大意义。

     通过SQLException.getErrorCode()可以捕获到自定义的异常错误编号。然后就可以,通过这个错误编号,自定义相应的Message内容,返回给客户了。

 

还有1个办法,就是存储过程返回值。可以直接把错误Message定义在返回值中间。这样Java端解析后,直接就可以取得Message代码了。

If  condition then 

   p_result := 'ERR:MSG2061';

end if;

if  substr(p_result, 1, 3)  = 'ERR' then

    ROLLBACK;

else

    p_result = 'OK';

end if;

 

Java:略去中间的调用存储过程的步骤

if(result != null && result.startsWith("ERR:"))

 // 从result中解析出Message_id,显示Message到前台

 

©著作权归作者所有:来自51CTO博客作者guojie的原创作品,如需转载,请注明出处,否则将追究法律责任

Oracle职场自定义Oracle


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消