- mysql的MyISAM引擎不支持回滚,如果需要自动回滚事务,需要将mysql的引擎设置成InnoDB;
- 在业务中抛出异常时,本应该被事务管理器捕获的异常,被手动catch处理了,或者事务结果未满足具体业务需求的,如果需要手动catch异常做业务处理,需要在catch里手动回滚事务TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(),或者在catch中主动抛出异常throw new RuntimeException();.
- 默认的spring事务只会捕获RuntimeException,如果是非运行时异常也需要进行事务回滚的话,可以在@Transactional注解中加上rollbackfor = Exception.class属性;
- 注解在public方法上,并且不要在本类中调用,否则不生效(AOP原理)
- 多数据源的项目中配置事务管理器,多数据源要区别配置不同数据源的事务管理器.默认会失效,不同数据库(mysql不同数据库,或者mysql/mongodb一起使用),注解需要指定使用的事务管理器,因为用到了mongdb的事务管理器,导致mysql回滚失效。
//mongod事务回滚配置
@Configuration
public class MongoTransactionConfig {
@Bean
MongoTransactionManager mongoTransactionManager(MongoDatabaseFactory factory) {
return new MongoTransactionManager(factory);
}
}
参考:https://blog.csdn.net/weixin_44138309/article/details/100561860