欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-03-13 16:58:06
在Controller 里 调用Service: orderRewardService.SaleRewardAndTransfer(kukaOrderRewardVo); 然后再service里 try catch,之前想着出现异常时若处理了异常,则程序不回滚, 于是Servie里catch里处理写 ......

 

在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,即详细的信息,方便检查错误。