小记——为什么@Transactional会失效?

前言

在项目开发中很多场景会用到事务,合理运用事务会提升代码的健壮性,我的猿子同事曾经做过一个实验,同一个方法中同时执行两个数据库语句,每1000条中大概有三到四条会出现数据插入不一致的情况,在数据量大的情况下,这个比例非常恐怖。

在事务的使用中应该注意以下三点:
1、使用@Transactional的方法必须是public修饰的。
2、使用@Transactional的方法不能再同类的其他方法中调用。
3、使用@Transactional只会对运行时异常回滚,IOException、SQLException及我们自定义的异常不会触发回滚。
重点是第三条,许多时候我们会自定义一下exception,这时候如何保证事务回滚呢?如下:@Transactional(rollbackFor = Exception.class)
这样就会保证我们遇到任何异常都会事务回滚!

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值