news 2026/5/12 4:50:57

如果spring事务中出现了RuntimeException CheckedException,事务会如何处理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如果spring事务中出现了RuntimeException CheckedException,事务会如何处理

Spring默认仅对RuntimeException及其子类、Error回滚事务,对IOException等Checked Exception不回滚;需用rollbackFor显式声明,且@Transactional仅对public方法生效,自调用、异常被吞等场景会导致失效。

Java中哪些异常会导致Spring事务自动回滚

Spring默认只对RuntimeException及其子类、Error触发事务回滚,对普通Exception(如IOExceptionSQLException)不会回滚。这是最容易踩的坑——你抛了Exception,数据库却已提交。

  • 显式声明回滚:用@Transactional(rollbackFor = Exception.class)覆盖默认行为
  • 避免吞掉异常:在try-catch中捕获后没重新抛出或没调用TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(),事务照样提交
  • checked exception不触发回滚不是Bug,是Spring的设计选择——它假设你捕获这类异常后会主动处理业务逻辑分支

@Transactional 失效的常见场景

事务失效往往和代理机制有关,不是配置错了,而是代码没落在Spring代理能拦截到的位置。

  • 自调用失效:同一个类里方法A调用本类的@Transactional方法B,B的事务注解不生效(因为走的是this.B(),没经过CGLIB/JDK代理)
  • 非public方法:@Transactional 只对public方法有效;protectedprivate或包级方法加了也无效
  • 异常被吞:catch住异常后既没throw,也没调用setRollbackOnly()
  • 使用了错误的事务管理器:比如配置了JpaTransactionManager,但DAO层用的是JDBC模板,事务无法传播

手动控制回滚:setRollbackOnly() vs throw新异常

当业务逻辑需要“条件性回滚”,又不想抛出异常中断流程时,setRollbackOnly()是唯一可靠方式。

  • 必须在事务上下文中调用:TransactionAspectSupport.currentTransactionStatus().setRollbackOnly()
  • 不能替代异常抛出:它只标记回滚,不终止方法执行;后续代码仍会运行,可能引发脏数据或NPE
  • 与throw对比:直接throwRuntimeException更清晰、更易测试;而setRollbackOnly()适合需要统一返回码、不暴露异常细节的API层

if(user.getBalance() < order.getAmount()) {

TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();

returnResult.fail("余额不足");

}

嵌套事务与REQUIRES_NEW的陷阱

PROPAGATION_REQUIRES_NEW看似能隔离子事务,但实际会挂起父事务,生成全新事务——这意味着父事务的隔离级别、超时设置、甚至数据库连接都失效了。

  • 日志/审计写入可能丢失:如果父事务回滚,而子事务(如发MQ消息)已提交,会出现状态不一致
  • 不能依赖父事务的数据库连接:REQUIRES_NEW 强制获取新连接,可能触发连接池耗尽
  • 慎用于“记录操作日志”:应优先用事件驱动或异步补偿,而非REQUIRES_NEW硬写库

真正需要隔离的场景,比如支付扣款+积分变更,建议拆成两个独立服务调用,靠最终一致性保障,而不是堆砌事务传播属性。

https://www.php.cn/faq/1998193.html

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/12 2:20:57

春节放假通知模板设计技巧:排版配色与文案撰写要点

春节放假通知模板&#xff1a;我的6年设计实战与工具推荐 作为一名在平面设计行业摸爬滚打了6年的内容创作者&#xff0c;我深刻体会到春节前夕那份特有的忙碌与期待。每年这个时候&#xff0c;无论是企业HR、行政人员&#xff0c;还是自媒体运营者&#xff0c;都会面临一个共…

作者头像 李华
网站建设 2026/5/12 2:20:58

改进粒子群算法的RSSI定位附matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f447; 关注我领取海量matlab电子书和…

作者头像 李华
网站建设 2026/5/12 2:21:49

【YOLOv13多模态创新改进】联合Mamba创新首发| SCI 一区2025| 引入CMFM 跨模态特征融合Mamba模块,实现 RGB与红外等多模态特征的高效融合,含多种创新改进,顶会顶刊发文热点

一、本文介绍 🔥本文给大家介绍使用 CMFM 跨模态特征融合Mamba模块改进 YOLOv13 多模态融合目标检测框架,可在保持实时性的前提下实现高效稳定的跨模态特征融合,充分利用可见光与红外信息的互补优势,显著提升复杂环境下的检测鲁棒性。该模块基于 Mamba 状态空间模型进行…

作者头像 李华
网站建设 2026/5/12 2:20:08

sql语言之分组语句group by

在sql语言中&#xff0c;group by 是分组语言语法是select 表达式 from 表名 group by 分组字段比如说上图的数据表&#xff0c;这是部分截图&#xff0c;表名叫table_tom&#xff0c;假如要按city字段进行分组&#xff0c;计算score各字段总和select sum("score") a…

作者头像 李华
网站建设 2026/5/12 2:20:08

jsp蛋糕甜品店管理系统4fx6j--(程序+源码+数据库+调试部署+开发环境)

本系统&#xff08;程序源码数据库调试部署开发环境&#xff09;带论文文档1万字以上&#xff0c;文末可获取&#xff0c;系统界面在最后面。 系统程序文件列表 用户,商品分类,商品尺寸,商品信息 开题报告内容 一、研究背景及意义 随着互联网的普及和消费者购物习惯的改变&…

作者头像 李华
网站建设 2026/5/1 9:53:04

PADS 多层板设计时怎么设置满足3W间距 或 不在某参考层布线

如何设置满足3W间距 在router中 右键选择网络 双击你要设置的网络 弹出 选择安全间距给这个网络添加一个特殊安全间距 比如其3w需10mil 我就 这样其与其他导线的安全距离就为10mil了 你布线时drc打开一不满足就会报错提示你 设置在参考层内不布线 如果你想要在哪个网络不…

作者头像 李华