java mysql事务嵌套_事务之六:spring 嵌套事务

本文详细介绍了Spring中嵌套事务的使用,包括Propagation.REQUIRED+Propagation.REQUIRES_NEW、Propagation.REQUIRED+Propagation.REQUIRED、Propagation.REQUIRED+无事务注解、内层事务被try-catch等情况下的事务行为。通过例子展示了不同配置下事务的回滚和提交规则,并强调了PROPAGATION_NESTED在满足特定需求时的价值,如‘联合成功’和‘隔离失败’。最后,文章提到了使用PROPAGATION_NESTED的必要条件,包括nestedTransactionAllowed属性设置和JDBC驱动的支持。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、基本概念

二、 嵌套事务示例

089bda3a7e1e16e6169af172726315fc.png

2.1、Propagation.REQUIRED+Propagation.REQUIRES_NEW

packagedxz.demo1;

@Servicepublic class ServiceAImpl implementsServiceA {

@AutowiredprivateServiceB serviceB;

@AutowiredprivateVcSettleMainMapper vcSettleMainMapper;

@Override

@Transactional(propagation= Propagation.REQUIRED, readOnly = false)public voidmethodA() {

String id= IdGenerator.generatePayId("A");

VcSettleMain vc=buildModel(id);

vcSettleMainMapper.insertVcSettleMain(vc);

System.out.println("ServiceAImpl VcSettleMain111:" +vc);

serviceB.methodB();

VcSettleMain vc2=buildModel(id);

vcSettleMainMapper.insertVcSettleMain(vc2);

System.out.println("ServiceAImpl VcSettleMain22222:" +vc2);

}privateVcSettleMain buildModel(String id) {

VcSettleMain vc= newVcSettleMain();

vc.setBatchNo(id);

vc.setCreateBy("dxz");

vc.setCreateTime(LocalDateTime.now());

vc.setTotalCount(11L);

vc.setTotalMoney(BigDecimal.ZERO);

vc.setState("5");returnvc;

}

}

ServiceB

packagedxz.demo1;

@Servicepublic class ServiceBImpl implementsServiceB {

@AutowiredprivateVcSettleMainMapper vcSettleMainMapper;

@Override

@Transactional(propagation= Propagation.REQUIRES_NEW, readOnly = false)public voidmethodB() {

String id= IdGenerator.generatePayId("B");

VcSettleMain vc=buildModel(id);

vcSettleMainMapper.insertVcSettleMain(vc);

System.out.println("---ServiceBImpl VcSettleMain:" +vc);

}

}

controller

packagedxz.demo1;

@RestController

@RequestMapping("/dxzdemo1")

@Api(value= "Demo1", descri

<think>嗯,用户想了解Spring事务嵌套,我需要详细解释清楚。首先,我应该从基本概念入手,介绍事务嵌套是什么。然后,可能需要讲传播机制,特别是PROPAGATION_REQUIRED和PROPAGATION_REQUIRES_NEW的区别。记得要举例子,比如方法A调用方法B,不同传播行为下的表现。 用户可能遇到事务嵌套的问题,比如内层事务回滚是否影响外层,或者如何配置不同的传播行为。需要说明默认的传播行为是什么,以及常见的使用场景。比如,当方法B需要独立事务时,使用REQUIRES_NEW,这样B的回滚不会影响A,但要注意异常处理。 另外,要提到事务的隔离级别和它们对嵌套事务的影响,但可能不需要太深入,除非用户特别问到。需要强调事务失效的常见情况,比如自调用问题,以及如何通过AOP代理解决。 还要注意语法部分,确保数学表达式和代码都用正确的格式。比如传播行为应该用代码块标出,例如@Transactional(propagation = Propagation.REQUIRES_NEW)。例子部分要清晰,可能用代码示例说明不同传播行为下的结果。 最后,总结一下关键点,帮助用户记忆。可能还需要提醒常见的陷阱,比如异常被捕获导致事务不回滚,或者配置错误导致传播行为不生效。确保回答结构清晰,分点说明,让用户容易理解。</think>Spring事务嵌套是分布式事务处理中的典型场景,其核心通过传播机制(Propagation Behavior)控制事务边界。以下从工作机制到实际场景逐步分析: 一、传播机制7种类型(关键4种) $$ \begin{array}{|l|l|} \hline \text{传播行为} & \text{行为特征} \\ \hline \text{PROPAGATION\_REQUIRED(默认)} & \text{加入当前事务,不存在则新建} \\ \hline \text{PROPAGATION\_REQUIRES\_NEW} & \text{始终新建独立事务} \\ \hline \text{PROPAGATION\_NESTED} & \text{嵌套事务(Savepoint机制)} \\ \hline \text{PROPAGATION\_SUPPORTS} & \text{跟随当前事务状态} \\ \hline \end{array} $$ 二、典型嵌套场景分析(A方法调用B方法) 1. **默认传播行为(REQUIRED)** ```java @Transactional void A() { insertTable1(); B(); // 传播行为=REQUIRED // 异常发生点影响最终结果 } @Transactional void B() { insertTable2(); } ``` - 若B()执行失败:A()中insertTable1和B()的insertTable2同时回滚 - 若B()成功,A()后续失败:所有操作回滚 2. **独立事务(REQUIRES_NEW)** ```java @Transactional void A() { insertTable1(); B(); // 传播行为=REQUIRES_NEW throw new Exception(); } @Transactional(propagation = Propagation.REQUIRES_NEW) void B() { insertTable2(); } ``` - B()的事务先提交 - A()抛出异常后,仅回滚insertTable1 3. **嵌套事务(NESTED)** ```java @Transactional void A() { insertTable1(); try { B(); // 传播行为=NESTED } catch (Exception e) { // 处理子事务异常 } insertTable3(); } @Transactional(propagation = Propagation.NESTED) void B() { insertTable2(); throw new RuntimeException(); } ``` - B()回滚到Savepoint,不影响A()后续insertTable3执行 - 需要数据库支持(如MySQL的InnoDB引擎) 三、实现原理 1. 通过`TransactionInterceptor`实现AOP切面 2. 使用`TransactionSynchronizationManager`管理事务上下文 3. 事务管理器(`PlatformTransactionManager`)决策传播行为 四、实践注意事项 1. **异常处理**:默认只回滚RuntimeException ```java @Transactional(rollbackFor = Exception.class) ``` 2. **事务失效场景**: - 自调用(同类中非代理方法调用) - 异常被捕获未抛出 - 非public方法 五、调试建议 1. 开启事务日志: ```properties logging.level.org.springframework.transaction.interceptor=TRACE logging.level.org.springframework.jdbc.datasource=DEBUG ``` 2. 使用`TransactionSynchronizationManager.isActualTransactionActive()`检测事务状态 理解事务嵌套的关键是掌握传播行为对事务边界的影响,实际开发中需要根据业务原子性要求选择合适的传播策略。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值