你以为自动开启?Spring 事务支持其实还需要这几步!

原文来自于:zha-ge.cn/java/110

你以为自动开启?Spring 事务支持其实还需要这几步!

有朋友问我:"咱们这个Spring的@Transactional不是加了就有用吗?明明写了注解,怎么数据还没回滚?"我一口老血险些喷出来。今天就聊一聊,这个看似贴心,实则有点坑的Spring事务自动支持,顺便聊点亲身"翻车"经历。


那一年,我天真地以为"它会为我全部安排"

初入Spring的时候,官网上的例子让我信誓旦旦。咱们的业务代码就一堆:

java 复制代码
@Transactional
public void transferMoney(Account from, Account to, BigDecimal amount) {
    from.withdraw(amount);
    to.deposit(amount);
    // 反正出错自动回滚吧
}

这,就是我的全部防线。

  • 以为只要加上@Transactional,万事OK;
  • 以为异常一抛出,就会自动ROLL BACK;
  • 以为......
  • 以为的都很美好,现实嘛,只有坑。

踩坑瞬间

说出来你别笑,真的有被气哭的冲动。

  1. 自己调用自己没炸开花? 方法A调方法B,B上挂了@Transactional,结果B挂了,事务没回滚。为什么?Spring事务代理是基于AOP做的,自己call自己直接调用了原生方法,代理不参与,事务"不感知"。

  2. 异常类型也分三六九等? 非运行时异常(比如Exception)抛出,没有回滚? 不骗你,Spring默认只对RuntimeExceptionError回滚,Catch到Exception手动抛了也不一定行。脑海里才浮现项目经理的残忍微笑。

  3. 少了配置,一切白搭? 没开@EnableTransactionManagement,你的@Transactional注解跟写笑话差不多......

代码片段是这样"错过"的:

java 复制代码
@Service
public class MoneyTransferService {
    @Transactional
    public void foo() { ... }

    public void bar() {
        this.foo(); // Spring无感知,直接裸奔
    }
}

你说气人不气人?


解决姿势

后来,老伙计们交了我几招。

  • 代理自己?用外部调用或者注入自身再调用。
    • applicationContext.getBean(MoneyTransferService.class).foo();
  • 抛异常?别自己捕获闷头吃,有需要就throw new RuntimeException();
  • 配置开关要开,否则全是"喷水池"。
    • @Configuration类上加@EnableTransactionManagement

经验启示

踩了这么多坑,留点彩蛋给大家:

遇到的问题 解决建议
方法内调用无效 用代理、注入自身bean调用
抛了Exception没回滚 只针对RuntimeException或自定义
配置项未启用 加@EnableTransactionManagement

顺手贴个配置样板:

java 复制代码
@Configuration
@EnableTransactionManagement
public class TxConfig {
    // 数据源/事务管理器配置省略
}

收个小尾巴

回头看吵吵嚷嚷那几次,恨不得给每个加@Transactional的老哥都发瓶红牛。 Spring事务能省心也能坑人,关键细节别假设"自动就给你安排清楚"。多踩几坑就记住了------写代码是自己的,掉进坑里只能自己爬,兄弟们共勉!

--- 以上,整个故事就这些。不聊了,我去修bug了 🤦‍♂️。

相关推荐
韩立学长1 分钟前
【开题答辩实录分享】以《智慧酒店管理——手机预订和住宿管理》为例进行选题答辩实录分享
android·java·后端
何中应1 分钟前
【面试题-8】Spring/Spring MVC/Spring Boot/Spring Cloud
java·spring boot·后端·spring·mvc·面试题
while(1){yan}6 分钟前
HTTP的数据报格式
java·开发语言·网络·网络协议·http·青少年编程·面试
武子康7 分钟前
大数据-186 Logstash JDBC vs Syslog Input:原理、场景对比与可复用配置(基于 Logstash 7.3.0)
大数据·后端·logstash
Baihai_IDP7 分钟前
对长上下文能力有不同要求,怎么选择合适的模型?
人工智能·面试·llm
真上帝的左手19 分钟前
15. 实时数据-SpringBoot集成WebSocket
spring boot·后端·websocket
han_hanker20 分钟前
springboot 封装的比较好的 统一的返回类型 工具类
java·spring boot·后端
韩立学长20 分钟前
基于Springboot流浪动物救助系统cqy142wz(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
怪只怪满眼尽是人间烟火21 分钟前
springboot数据上链FISCO BCOS
java·spring boot·后端
她说..25 分钟前
Spring AOP场景5——异常处理(附带源码)
java·数据库·后端·spring·springboot·spring aop