当前位置: 首页 > article >正文

Spring事务与事务传播机制教程|从入门到实战,一篇吃透@Transactional

—JavaEE专栏—Spring事务与事务传播机制教程从入门到实战一篇吃透Transactional大家好我是一名后端开发今天带来一篇Spring事务传播机制的硬核实战博客包含原理代码图文面试高频完整实战案例看完彻底搞定Spring事务再也不怕数据不一致 前言为什么要学Spring事务保证原子性要么全成功要么全回滚解决数据一致性转账、下单、注册等核心业务必备面试必问事务隔离级别、传播机制、Transactional失效场景本文基于SpringBoot从基础事务操作 → 编程式/声明式事务 → 隔离级别 →7大传播机制附带8个真实业务事务案例小白也能直接运行复现一、数据库事务基础回顾事务就是一组不可分割的操作遵循ACID原则原子性全部成功 or 全部失败一致性执行前后数据合法隔离性多事务互不干扰持久性提交后永久生效MySQL原生事务操作-- 开启事务STARTTRANSACTION;/BEGIN;-- 业务SQLINSERTINTOuser_info...;-- 提交/回滚COMMIT;ROLLBACK;缺点代码冗余、侵入性强Spring帮我们自动化二、Spring事务两种实现方式Spring提供编程式和声明式两种事务开发中99%用声明式。1. 编程式事务手动控制事务开启、提交、回滚代码繁琐适合特殊场景。核心对象DataSourceTransactionManager事务管理器TransactionDefinition事务属性TransactionStatus事务状态RestControllerRequestMapping(/user)publicclassUserController{AutowiredprivateDataSourceTransactionManagertransactionManager;AutowiredprivateTransactionDefinitiontransactionDefinition;AutowiredprivateUserServiceuserService;RequestMapping(/registry)publicStringregistry(Stringname,Stringpassword){// 1.开启事务TransactionStatusstatustransactionManager.getTransaction(transactionDefinition);try{// 2.执行业务userService.registryUser(name,password);// 3.提交transactionManager.commit(status);return成功;}catch(Exceptione){// 4.异常回滚transactionManager.rollback(status);return失败;}}}2. 声明式事务重点Transactional只需一个注解自动开启、提交、回滚基于AOP实现无侵入性两步使用引入事务依赖SpringBoot已自动集成dependencygroupIdorg.springframework/groupIdartifactIdspring-tx/artifactId/dependency方法/类上添加TransactionalServicepublicclassUserService{AutowiredprivateUserInfoMapperuserInfoMapper;// 声明事务TransactionalpublicvoidregistryUser(Stringname,Stringpassword){userInfoMapper.insert(name,password);}}✨ Transactional 核心规则修饰public方法*才生效方法正常执行自动提交抛出未捕获异常自动回滚异常被捕获→ 不回滚三、Transactional 三大核心属性1. rollbackFor指定回滚异常默认只回滚RuntimeException Error编译期异常如IOException不回滚// 所有异常都回滚推荐配置Transactional(rollbackForException.class)2. isolation事务隔离级别Spring支持5种隔离级别对应MySQL4种默认级别含义解决问题DEFAULT跟随数据库默认-READ_UNCOMMITTED读未提交脏读READ_COMMITTED读已提交脏读REPEATABLE_READ可重复读不可重复读SERIALIZABLE串行化脏读、不可重复读、幻读使用Transactional(isolationIsolation.READ_COMMITTED)3. propagation事务传播机制多个事务方法互相调用时事务如何传递Spring定义7种传播机制重点掌握REQUIRED、REQUIRES_NEW、NESTED【实战必看】8个Spring事务真实案例事务提交、回滚、异常捕获、手动回滚、编译异常回滚等所有高频场景可直接测试的Controller接口完整Controller代码packagecn.overthinker.trans.controller;importcn.overthinker.trans.entity.UserInfo;importcn.overthinker.trans.service.UserService;importlombok.extern.slf4j.Slf4j;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.transaction.annotation.Isolation;importorg.springframework.transaction.annotation.Transactional;importorg.springframework.transaction.interceptor.TransactionAspectSupport;importorg.springframework.web.bind.annotation.RequestMapping;importorg.springframework.web.bind.annotation.RestController;importjava.io.IOException;Slf4jRestControllerRequestMapping(/trans)publicclassTransController{AutowiredprivateUserServiceuserService;/** * 1. 正常事务提交无异常 → 数据入库成功 */TransactionalRequestMapping(/registry)publicStringregistryUser(UserInfouserInfo){//用户注册userService.insertUser(userInfo);return用户注册成功事务已提交;}/** * 2. 抛出未捕获异常 → 事务自动回滚 * 结果数据不会插入数据库 */TransactionalRequestMapping(/r2)publicStringr2(UserInfouserInfo){//用户注册IntegerresultuserService.insertUser(userInfo);log.info(数据插入成功影响行数result);// 主动抛运行时异常inta10/0;return用户注册成功;}/** * 3. 异常被try-catch捕获 → 事务【不会回滚】 * 结果数据成功入库经典坑点 */TransactionalRequestMapping(/r3)publicStringr3(UserInfouserInfo){//用户注册IntegerresultuserService.insertUser(userInfo);log.info(数据插入成功影响行数result);try{inta10/0;}catch(Exceptione){log.error(程序发生异常被捕获事务不回滚);}return用户注册成功数据已入库;}/** * 4. 捕获异常后重新抛出 → 事务【正常回滚】 * 结果数据不会入库 */TransactionalRequestMapping(/r4)publicStringr4(UserInfouserInfo){//用户注册IntegerresultuserService.insertUser(userInfo);log.info(数据插入成功影响行数result);try{inta10/0;}catch(Exceptione){log.error(程序发生异常被捕获重新抛出异常);throwe;}return用户注册成功;}/** * 5. 捕获异常 手动回滚 → 事务【回滚】 * 结果数据不会入库接口正常返回 */TransactionalRequestMapping(/r5)publicStringr5(UserInfouserInfo){//用户注册IntegerresultuserService.insertUser(userInfo);log.info(数据插入成功影响行数result);try{inta10/0;}catch(Exceptione){log.error(程序发生异常被捕获手动回滚事务);// 手动触发事务回滚TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();}return用户注册失败事务已手动回滚;}/** * 6. 抛出编译期异常(IOException) → 事务【不回滚】 * 默认规则只回滚 RuntimeException/Error */TransactionalRequestMapping(/r6)publicStringr6(UserInfouserInfo)throwsIOException{//用户注册IntegerresultuserService.insertUser(userInfo);log.info(数据插入成功影响行数result);if(true){// 编译期异常默认不回滚thrownewIOException();}return用户注册成功IO异常未回滚;}/** * 7. 配置 rollbackForException.class → 所有异常都回滚 * 结果IOException 也会触发回滚 */Transactional(rollbackForException.class,isolationIsolation.READ_COMMITTED)RequestMapping(/r7)publicStringr7(UserInfouserInfo)throwsIOException{//用户注册IntegerresultuserService.insertUser(userInfo);log.info(数据插入成功影响行数result);if(true){thrownewIOException();}return用户注册成功IO异常已回滚;}} 案例效果总结接口事务表现核心结论/trans/registry正常提交无异常自动提交/trans/r2自动回滚运行时异常自动回滚/trans/r3不回滚异常被catch事务失效大坑/trans/r4自动回滚捕获后重新抛出生效/trans/r5手动回滚手动控制事务灵活安全/trans/r6不回滚默认不回滚编译期异常/trans/r7自动回滚配置rollbackFor后全异常回滚⚠️ Transactional 常见失效场景非public方法→ 不生效异常被try-catch吃掉→ 不回滚未指定rollbackFor→ 编译异常不回滚同类方法内部调用→ AOP不生效数据库引擎不支持事务如MyISAM四、7大事务传播机制详解图文代码先统一场景用户注册 记录日志两个带事务的方法互相调用。1. REQUIRED默认值 ✅ 最常用有事务加入无事务新建Transactional(propagationPropagation.REQUIRED)内外共用同一个事务一方异常 →全部回滚适用常规业务增删改演示日志方法抛异常 → 用户数据也回滚2. REQUIRES_NEW独立事务 ✅ 高频无论如何都新建事务挂起外层事务Transactional(propagationPropagation.REQUIRES_NEW)内外完全独立日志异常 → 不影响用户注册适用日志、审计、消息发送必须独立成功演示日志失败 → 用户依然注册成功3. NESTED嵌套事务 ✅ 高级有事务则嵌套Savepoint无则同REQUIREDTransactional(propagationPropagation.NESTED)子事务可单独回滚不影响父事务父事务回滚 → 子事务必回滚依赖数据库Savepoint4. SUPPORTS有事务就加无事务非事务运行适用查询操作5. MANDATORY必须有事务无事务直接抛异常适用强制运行在事务内的核心逻辑6. NOT_SUPPORTED非事务运行有事务也挂起适用不需要事务的操作7. NEVER禁止事务有事务抛异常适用明确不能在事务中运行的方法 传播机制核心对比表类型外层有事务外层无事务核心特点场景REQUIRED加入新建共用事务通用业务REQUIRES_NEW新建并挂起新建独立事务日志NESTED嵌套子事务新建局部回滚复杂批量SUPPORTS加入非事务灵活查询MANDATORY加入抛异常强制事务核心逻辑NOT_SUPPORTED挂起非事务无事务非核心操作NEVER抛异常非事务禁止事务安全方法七、总结Spring事务编程式手动声明式Transactional三大属性rollbackFor、isolation、propagation7大传播机制重点REQUIRED、REQUIRES_NEW、NESTED实战8大案例覆盖所有事务坑点直接复制测试开发规范增删改用REQUIRED日志用REQUIRES_NEW

相关文章:

Spring事务与事务传播机制教程|从入门到实战,一篇吃透@Transactional

—JavaEE专栏— Spring事务与事务传播机制教程|从入门到实战,一篇吃透Transactional 大家好,我是一名后端开发,今天带来一篇Spring事务传播机制的硬核实战博客,包含原理代码图文面试高频完整实战案例,看完…...

告别VNC卡顿!用NoMachine远程桌面连接树莓派5的保姆级教程(含ARM架构选择避坑)

树莓派5远程桌面革命:NoMachine极致流畅体验全指南 树莓派作为开发者的迷你工作站,远程桌面体验一直是痛点。传统VNC协议的高延迟让代码调试、图形操作变得异常痛苦。本文将彻底改变这一局面——基于NX协议的NoMachine能实现60fps的流畅远程桌面&#xf…...

Verdi Transaction Debug避坑指南:从环境变量配置到FSDB文件生成,解决monitor采集不到Transaction的常见问题

Verdi Transaction Debug全流程实战:从环境配置到高级调试技巧 刚接触Verdi Transaction Debug功能的验证工程师们,是否遇到过这样的场景:你按照教程配置好了所有环境变量,编译了带UVM的测试平台,满心期待地在Verdi中打…...

告别接线烦恼!用JDY-23蓝牙模块DIY一个手机遥控的智能小夜灯(附Arduino代码)

用JDY-23蓝牙模块打造手机遥控的智能小夜灯 深夜起床开灯太刺眼?传统小夜灯需要手动开关太麻烦?今天我们就用JDY-23蓝牙模块和Arduino,DIY一个可以通过手机APP远程控制的智能小夜灯。这个项目不仅实用,还能让你深入了解蓝牙通信和…...

从频谱分析到PCB布线:开关电源EMI优化的5个关键步骤(附实测数据)

从频谱分析到PCB布线:开关电源EMI优化的5个关键步骤(附实测数据) 在实验室的示波器前,我们常常会看到这样的场景:工程师盯着屏幕上跳动的波形和杂乱的频谱图皱眉——开关电源的EMI问题又来了。无论是传导干扰超标还是辐…...

别再为加工发愁!手把手教你将HFSS的3D模型变成Altium可用的PCB封装(以定向耦合器为例)

高频PCB封装实战:从HFSS仿真到Altium可复用封装库的完整指南 在射频电路设计中,定向耦合器、滤波器等特殊结构往往需要先在HFSS中进行电磁仿真优化,再转化为实际PCB布局。传统做法是每次设计都重新绘制封装,既低效又容易引入误差。…...

AI未来3-5年十大核心方向

基于对人工智能领域趋势的分析,未来3-5年,以下十个核心方向将深刻影响技术演进与社会变革。1. 多模态大模型与全能模型 (Omni-Multimodal Models)技术发展:多模态预训练大模型将成为AI技术栈的标配,能够无缝理解和生成文本、图像、…...

【实战指南】利用再生龙(Clonezilla)实现Linux服务器整盘灾备

1. 为什么选择再生龙做服务器灾备? 第一次听说再生龙(Clonezilla)是在五年前,当时公司的测试服务器突然硬盘故障,整整两周的开发进度差点泡汤。从那时起我就开始研究各种系统级备份方案,试过dd命令、rsync脚…...

Lychee多模态重排序模型效果展示:T→T纯文本检索中长尾query高分匹配案例

Lychee多模态重排序模型效果展示:T→T纯文本检索中长尾query高分匹配案例 1. 引言:当搜索遇到“冷门”问题 想象一下,你在网上搜索一个非常具体、甚至有点冷门的问题。比如,你想知道“如何用Python代码实现一个能识别手写数字的…...

从‘乐学小鹅’到‘com.tencent.k12gy’:一次Frida注入失败带给我的Android应用‘身份证’认知升级

从应用显示名到包名:一次Frida注入失败引发的Android应用标识深度思考 那天下午,我盯着终端里刺眼的红色错误信息,手指悬在键盘上方迟迟没有动作。Failed to spawn: unable to find application with identifier 乐学小鹅——这个看似简单的报…...

备件断供时代:中短波发射机国产化替代的真实进展

本文是工程四部曲之四。此前三篇分别拆解了中波台的运营成本(OPEX篇)、发射机的全生命周期成本、以及天馈系统的数字化适配。本篇文章,我们将把目光转向设备供应链本身——你想买的东西,还买得到吗? 一根导火索 2026年…...

Leaflet结合天地图实现动态主题切换与个性化地图定制

1. 理解Leaflet与天地图的角色定位 Leaflet作为轻量级开源地图库,就像一张可以自由绘画的透明画布。我在实际项目中发现,它最强大的能力在于提供地图交互骨架——缩放、拖拽、标记等基础功能全部开箱即用。而天地图则像是专门为中国地区优化的彩色颜料&a…...

宝塔面板一键部署前端项目:新手避坑指南

1. 为什么选择宝塔面板部署前端项目 第一次接触服务器部署的朋友,看到nginx配置里那些server_name、location规则估计头都大了。我当年也是这样,光是配个反向代理就折腾了一整天。后来发现宝塔面板这个神器,部署效率直接提升10倍不止。 宝塔最…...

救命!SQL注入居然这么好懂|小白零门槛实操复盘

家人们!网安进阶必冲的“入门王者”漏洞非SQL注入莫属——全程贯穿Web渗透,红队老哥打攻击必用它,蓝队防守也得重点盯防!纯干货实操双在线,刚入坑的网安小白直接码住,照着学不踩坑~先给各位搭子…...

Rust的零大小类型ZST与幽灵数据PhantomData在类型系统中的作用

Rust语言以其独特的所有权系统和类型安全著称,而零大小类型(ZST)与幽灵数据(PhantomData)则是其类型系统中两个精妙的设计。它们看似无形,却在编译期静态检查、内存优化和泛型约束中扮演着关键角色。本文将…...

华为OD机试真题 新系统 - 直捣黄龙 (C/C++/Py/Java/Js/Go)

直捣黄龙 华为OD机试真题 华为OD上机考试真题 4月8号 200分题型 华为OD机试真题目录点击查看: 华为OD机试真题题库目录|机考题库 + 算法考点详解 题目描述 小王在玩一款叫做直捣黄龙的小游戏,在该游戏中他需要从入口位置进入敌营,绕过哨兵的层层封锁,达到敌军司令部实施…...

FastbootEnhance完整指南:Windows平台最友好的Fastboot工具箱实战解析

FastbootEnhance完整指南:Windows平台最友好的Fastboot工具箱实战解析 【免费下载链接】FastbootEnhance A user-friendly Fastboot ToolBox & Payload Dumper for Windows 项目地址: https://gitcode.com/gh_mirrors/fa/FastbootEnhance FastbootEnhanc…...

数据预处理方法

数据预处理是数据分析与挖掘的关键环节,其质量直接影响模型的准确性和可靠性。在现实场景中,原始数据往往存在噪声、缺失或格式不一致等问题,若不加以处理,可能导致分析结果偏差甚至失效。掌握高效的数据预处理方法成为数据科学家…...

SSTI漏洞学习笔记

一,SSTI漏洞原理 SSTI(Server-Side Template Injection)是一种服务器端模板注入漏洞,发生在应用程序使用模板引擎渲染用户输入时未能正确过滤或转义用户提供的内容。 服务端模板:有很多网页是使用模板生成的html页面…...

【单片机】架构设计

以上只是理想架构,或者说和RT-Thread一样,实际做项目往这个上面靠即可。...

MATLAB/Simulink搭建全桥LLC仿真:从参数计算到波形调试的保姆级避坑指南

MATLAB/Simulink全桥LLC仿真实战:从理论参数到波形优化的工程化实现 电力电子工程师在设计全桥LLC谐振变换器时,仿真环节往往是理论走向实践的第一道门槛。许多初学者在Simulink中搭建模型时,明明按照教科书计算了Lr、Lm、Cr等参数&#xff0…...

CMMI认证避坑指南:中小企业如何用最低成本拿下3级认证(附实战案例)

CMMI认证避坑指南:中小企业如何用最低成本拿下3级认证(附实战案例) 对于许多中小企业来说,CMMI认证似乎是一个遥不可及的目标——高昂的咨询费用、复杂的文档要求、漫长的准备周期,每一项都让资源有限的团队望而却步。…...

使用Microsoft Agent Framework构建C# AI代理雍

简介 langchain中提供的chain链组件,能够帮助我门快速的实现各个组件的流水线式的调用,和模型的问答 Chain链的组成 根据查阅的资料,langchain的chain链结构如下: $$Input \rightarrow Prompt \rightarrow Model \rightarrow Outp…...

从81.7万细胞中解码“语法”:人类发育多组学图谱首次揭示调控序列的硬规则与软约束

论文信息标题:Multiomics and deep learning dissect regulatory syntax in human development期刊/会议:Nature发表时间:25 February 2026论文链接:https://doi.org/10.1038/s41586-026-10326-9从81.7万细胞中解码“语法”&#…...

告别零样本提示:为什么在复杂业务里,Text2SQL微调才是王道?以DB-GPT-Hub为例

为什么Text2SQL微调在复杂业务场景中不可替代?DB-GPT-Hub实战解析 当企业数据库遇到多表关联、嵌套查询和业务专属术语时,传统零样本提示方法的SQL生成准确率往往会断崖式下跌。去年某金融科技团队在迁移核心交易系统时发现,即使使用顶级大模…...

【LeetCode刷题日记】:从 LeetCode 经典题看哈希表的场景化应用---数组、HashSet、HashMap 选型与算法实战

🔥个人主页:北极的代码(欢迎来访) 🎬作者简介:java后端学习者 ❄️个人专栏:苍穹外卖日记,SSM框架深入,JavaWeb ✨命运的结局尽可永在,不屈的挑战却不可须臾或…...

2026最权威的十大AI辅助论文方案解析与推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 一篇篇DeepSeek系列论文,呈现出大型语言模型架构以及训练方法方面的系统性创新&a…...

2026最权威的六大AI科研工具实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 于学术写作范畴之内,论文AI工具正一步一趋成为研究者的关键辅助方式,…...

第16讲:C语⾔内存函数

目录 memcpy使⽤memmove使⽤memset函数的使⽤memcmp函数的使⽤1.memcpy(1)功能: memcpy 是完成内存块拷⻉的,不关注内存中存放的数据是啥。函数 memcpy 从 source 的位置开始向后复制 num 个字节的数据到 destination 指向的内存位…...

技术选型评估框架需求技术与团队匹配

技术选型评估框架:需求、技术与团队的精准匹配 在快速迭代的软件开发领域,技术选型直接决定项目的成败。如何从众多技术方案中选出最适合团队与业务需求的工具?关键在于构建一个科学的技术选型评估框架,确保需求、技术与团队能力…...