免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1520 | 回复: 0
打印 上一主题 下一主题

mysql存储过程异常处理? [复制链接]

论坛徽章:
1
亥猪
日期:2013-10-30 23:29:55
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-02-28 13:01 |只看该作者 |倒序浏览
使用mybatis做orm框架,在mysql中添加了一个存储过程,用到了事务,并且存储过程里面添加了异常处理的handler,如果捕获异常,将直接rollback,并退出,部分代码如下:
  1. begin
  2.     declare v_count  int;
  3.     declare v_status varchar(50);
  4.     declare exit handler for sqlexception
  5.     begin
  6.     set out_result='SYSTEM EXCEPTION, ROLL BACK';
  7.     rollback;
  8.     end;
  9.     declare exit handler for sqlwarning
  10.     begin
  11.     set out_result='SYSTEM WARN, ROLL BACK';
  12.     rollback;
  13.     end;
  14.     start transaction;
  15.     select count(ssoid) into v_count from userinfo where ssoid=p_userId;
  16.     /*if v_count <= 0 then */
  17.     insert into userinfo(ssoid, balance) values(p_userId, 0);
  18.     /*end if; */
  19.     ;
  20.     commit;
  21.    
  22.     end
复制代码
insert由于唯一索引,报异常,进入declare exit handler for sqlexception执行,并返回,但是mybatis并不能捕获这个异常,如果上线,那我岂不是看不到完整的异常栈信息,这里有其他处理办法吗?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP