1
- mysql的MyISAM引擎不支持回滚,如果需要自动回滚事务,需要将mysql的引擎设置成InnoDB;
2
在业务中抛出异常时,本应该被事务管理器捕获的异常,被手动catch处理了,或者事务结果未满足具体业务需求的,如果需要手动catch异常做业务处理,需要在catch里手动回滚事务TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(),或者在catch中主动抛出异常throw new RuntimeException();.
两个必要
例如:
@Transactional(rollbackFor = Exception.class) //必要1
@Override
public Boolean testTransaction(String param) {
try {
deleteXX();
insertXX();
return true;
} catch (Exception e) {
TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); //必要2
log.error("异常",e);
return false;
}
}
3
- 默认的spring事务只会捕获RuntimeException,如果是非运行时异常也需要进行事务回滚的话,可以在@Transactional注解中加上rollbackfor = Exception.class属性;
本文介绍了MySQL中MyISAM与InnoDB存储引擎的区别,特别是关于事务支持的特点。此外,还详细探讨了如何在Spring框架中正确配置和使用事务管理器,包括异常处理和手动回滚的具体实现。
1896

被折叠的 条评论
为什么被折叠?



