当前位置: 移动技术网 > IT编程>开发语言>Java > 记一次异常处理很失败的经历

记一次异常处理很失败的经历

2019年04月13日  | 移动技术网IT编程  | 我要评论

 

在controller 里 调用service:

 

orderrewardservice.salerewardandtransfer(kukaorderrewardvo);

 

然后再service里 try catch,之前想着出现异常时若处理了异常,则程序不回滚,

 

于是servie里catch里处理写成了这样:

 

try{

  //程序与数据库交互,逻辑处理

} catch(exception e){

  log.error("处理异常,errormsg: "+e.getmessage());

}

 

这样以来数据报异常后,没有打印异常详细信息,只有一个message ,而且不是不写e.printtrack()就回滚了,

 

而是需要抛出去异常,才能正常回滚。

 

总结: 1. 方法中需要回滚时,尽量把异常抛出去,框架如spring boot可以在方法上加注解:@transactional 可以自动回滚,

 

    简单的项目中需要手动回滚。

 

    2.在容易出现异常的地方,尽量输出 e,即详细的信息,方便检查错误。

 

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网