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

前言


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


在事务的使用中应该注意以下三点:

1、使用@Transactional的方法必须是public修饰的。

2、使用@Transactional的方法不能再同类的其他方法中调用。

3、使用@Transactional只会对运行时异常回滚,IOException、SQLException及我们自定义的异常不会触发回滚。

重点是第三条,许多时候我们会自定义一下exception,这时候如何保证事务回滚呢?如下:@Transactional(rollbackFor = Exception.class)

这样就会保证我们遇到任何异常都会事务回滚!


上一篇:死锁


下一篇:最短路径问题(迪杰斯特拉)算法