默认仅RuntimeException和Error触发Spring事务回滚;检查异常需通过rollbackFor显式配置;事务失效还常因方法非public、自调用、未启用事务管理等导致。

在Java中,异常确实可能导致事务失效或触发回滚,但并非所有异常都会导致事务回滚,关键取决于异常类型、事务配置方式(如Spring的@Transactional)以及传播行为等细节。
Spring的@Transactional默认只对未检查异常(即继承自RuntimeException)和Error自动回滚。比如:
NullPointerExceptionIllegalArgumentExceptionOutOfMemoryError而像IOException、SQLException这类检查异常(Checked Exception),即使抛出,事务也不会自动回滚——除非显式配置。
通过@Transactional的rollbackFor属性指定:
立即学习“Java免费学习笔记(深入)”;
@Transactional(rollbackFor = {IOException.class, SQLException.class})也可以写成更宽泛的形式:
rollbackFor = Exception.class(慎用,可能掩盖预期的业务异常处理逻辑)noRollbackFor = {CustomBizException.class}:明确排除某些异常不回滚比异常更隐蔽的是事务根本没生效,常见情况包括:
public:Spring AOP代理仅对public方法生效@Transactional的方法B,B的事务注解不会生效(代理未介入)@EnableTransactionManagement或对应XML配置transactionManager
除了声明式事务,还可以编程式干预:
TransactionAspectSupport.currentTransactionStatus().setRollbackOnly()
注意:该操作不可逆,且需确保当前确实在事务上下文中,否则会抛NoTransactionException。
事务回滚机制不是“有异常就回滚”的简单逻辑,而是由框架规则、配置和代码结构共同决定的。理解默认行为、明确配置意图、排查代理失效点,才能真正掌控事务边界。
以上就是在Java里异常是否会导致事务失效_事务回滚机制解析的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号