SpringBoot事务处理总结

Spring boot是默认启动事务的,只需要在类或者方法上添加@Transactional注解即可,但有时候会发现事务不生效,具体原因可以从以下几个方面找寻:

1、首先要看数据库引擎是否支持注解,mysql默认引擎INNODB是支持的但MYISAM是不支持的

2、注解只能被应用到public方法上, 其它方法上不会报错,但不生效;

3、默认情况下只会对运行期异常(java.lang.RuntimeException及其子类)和 Error 进行回滚
SpringBoot事务处理总结4、如果是其它异常,可以显形标记在参数里,下图标红的就是先进行查看用户有指定的异常,如果没有,就默认上一条的异常,参数格式:@Transactional(rollbackFor={Exception.class})
SpringBoot事务处理总结5、是否进行了异常捕获,如果使用了try–catch,事务是肯定不生效,也就是系统没有接收到异常场景;
关于使用异常捕获,还想事务生效,可以有几种策略解决相关难题:

5.1、手动回滚
SpringBoot事务处理总结
5.2、在catch里抛出一个runntimeException
SpringBoot事务处理总结
5.3、将异常写入注解参数里面,也需要抛出来,原理跟方法2一样的,只是重新指定了事务回滚的异常类型
SpringBoot事务处理总结
隔离级别.
SpringBoot事务处理总结Mysql默认采用 REPEATABLE_READ 隔离级别
Oracle默认采用 READ_COMMITTED 隔离级别