事务没生效还以为成功了?Spring 事务失效的雷区你中招了吗?

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

事务没生效还以为成功了?Spring 事务失效的雷区你中招了吗?

最近公司新来的小伙伴,写业务像打王者,新手村野怪都挡不住。但代码上线后,同步库存居然没 rollback!你没看错,就是传说中「事务没生效还以为自己天下无敌」的滑铁卢。看着一堆乐观脸的日志,我也忍不住怀疑:难道 Spring 事务真有我的克星?

房间里的大象:Spring 事务你真的懂了吗?

其实当年我刚摸 Spring 的时候,也是总觉得加了 @Transactional,就像用了金箍棒,后端没人搞得定我数据了。于是,神马转账、扣库存、改积分,统统一把梭。但理想很丰满,现实很骨感。

因为:

  • 代码能跑,效果没报错,可数据!没回滚!
  • 日志一切正常,回头一看,天呐,我的钱居然没回来了。

所以,今天给大家聊聊几种最容易踩的「Spring 事务是一片滩涂」的时刻。

踩坑瞬间

来,直接上事例,大家自测下中招没:

  1. 自我调度,事务自杀 你写了个方法A加了@Transactional,然后在同类的另一个方法B里,直接this.aMethod()

    java 复制代码
    @Transactional
    public void aMethod() {
        // DB操作......
    }
    
    public void bMethod() {
        this.aMethod(); // 啪,事务不会生效!
    }

    Spring 事务有点像「旁观者清」,得靠"代理"来戴帽子,自己 call 自己,Spring 懒得理你。

  2. 非 public 方法,事务没机会出场 你耍帅,想写个private/protected方法,再上个@Transactional,结果...Spring 事务爱理不理。

  3. 异常是"绅士",不回滚 你抛了个try-catch,或者抛个检查异常(不是RuntimeException),Spring 默默微笑,数据不 rollback,你看着办吧!

  4. AOP代理模式玩花样,CGLIB vs JDK 你 bean 配的不对,用了接口却搞 CGLIB,或者没接口强行用 JDK Proxy,Spring 事务直接说:你高兴就好,我给你个假笑。

  5. 数据库驱动不支持事务,春梦一场 别问为什么 SQLite、MyISAM 下 rollback 永远无感,问就是单身狗谈理想。

找坑技能树

怕踩坑,得学会查案现场。我的几个灵魂发问:

  • 数据库事务日志到底生效了没?
  • 代码是不是 public?
  • 有无"自我调用"?(自己递归自己,很危险欸)
  • catch 语句是不是贼多?
  • 事务注解写没写错?(常写成Transaction
  • 配置信息里,AOP模式对吗?
  • 业务是不是在事务之外调了危险代码?

每次出事,我都是这几套组合拳一遍遍盘。

经验启示

踩雷千百遍,套路总结如下:

  • 千万别自我调用带@Transactional的方法,要有接口或者在 Spring 管理下让"代理"出面。

  • 只对 public 方法加事务,别和 Spring 抬杠。

  • 想让某些受检异常也能 rollback?补个参数:

    java 复制代码
    @Transactional(rollbackFor = Exception.class)
  • 日常加一点断言+日志,把所有事务事故暴露在阳光下,不要藏头缩尾。

  • 实在搞不懂,可以 debug 看 Spring AOP 代理结构,一目了然。

收个尾巴

说到底,Spring 事务这玩意儿,看起来像金钟罩,实际上挺玻璃心的。翻车时候风轻云淡,不出错时候你都感受不到它存在。遇坑别沮丧,一次踩坑等于买一个新技能。下次事务再掉线,你就能「呵呵一笑」摸着头皮修好它。

大家还见过啥奇葩的事务"假动作"吗?评论区聊聊呗~

相关推荐
教游泳的程序员3 小时前
【JDBC】系列文章第一章,怎么在idea中连接数据库,并操作插入数据?
java·ide·mysql·intellij-idea
懒羊羊不懒@3 小时前
C语言指针进阶(进阶)
java·开发语言·面试
nlog3n3 小时前
分布式秒杀系统设计方案
java·分布式
间彧3 小时前
JWT(JSON Web Token)详解
java
前路不黑暗@3 小时前
Java:代码块
java·开发语言·经验分享·笔记·python·学习·学习方法
canonical-entropy3 小时前
NopReport示例-动态Sheet和动态列
java·windows·可逆计算·nop平台·报表引擎
zero13_小葵司4 小时前
基于Springboot的DDD实战(不依赖框架)
java·spring boot·log4j
韩立学长4 小时前
【开题答辩实录分享】以《服装定制系统的设计与实现》为例进行答辩实录分享
java·安卓
聪明的笨猪猪4 小时前
Java SE “核心类:String/Integer/Object”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试