记一次异常处理很失败的经历
程序员文章站
2022-06-18 08:49:10
在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,即详细的信息,方便检查错误。
上一篇: ps怎么制作逼真的雨点效果?
下一篇: 利用GO语言实现多人聊天室实例教程