编程式事务 声明式事务问题分析

编程式事务 声明式事务问题分析

问题梳理:

在代码测试过程中发现在某业务场景下,事务失效(具体表现: 数据推送下游系统失败(报错在数据封装环节),但是保存成功)
已知,推送逻辑中,数据保存成功,推送数据的封装一定会成功,于是开始排查问题

问题排查:

发现之前的编程式事务中被嵌套了声明式事务注解@Transactional(propagation = Propagation.REQUIRES_NEW)
猜想问题可能由于两种事务实现方式冲突产生,于是对问题进行拆解分析。首先对新加的声明式事务进行还原,测试发现问题解决。
接着对问题的产生进行分析,此前个人一直理解编程式事务的使用 是新起一个事务只对被包含的部分代码生效,效果与声明式事务注解
@Transactional(propagation = Propagation.REQUIRES_NEW)相同,后测试发现 使用编程式事务transactionTemplate 跟@Transactiona
注解效果相同 如果在使用编程式事务前已经有事务开始,则编程式事务会继承之前的事务,而不会新启一个新的事务。 反之,则会新起一个新的事务。 并且在声明式事务与编程式事务同时作用于一个方法时,声明式事务的优先级更高。

本问题产生原因总结为:

@Transactional(propagation = Propagation.REQUIRES_NEW)注解优先级高于原先的编程式事务,使数据持久化时新起了一个新的事务,而在新事务执行完毕后。老事务的版本号因为低于新事物,查询不到新事务保存的数据,从而报错出现问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring框架提供了两种事务管理方编程事务管理和声明式事务管理。 1. 编程事务管理: 编程事务管理是通过编写代码来管理事务的提交和回滚。在这种方下,开发人员需要手动编写事务的开始、提交和回滚的代码。Spring提供了`TransactionTemplate`和`TransactionDefinition`等类来简化编程事务管理的操作。通过使用`TransactionTemplate`,可以在需要进行事务处理的代码块中对事务进行管理。 2. 声明式事务管理: 声明式事务管理是通过配置的方来管理事务的提交和回滚,而不需要手动编写事务管理的代码。在这种方下,开发人员只需要在需要进行事务处理的方法上使用注解或者XML配置文件来声明事务的属性,Spring框架就会根据配置自动实现事务管理。常见的注解方是使用`@Transactional`注解。 两种事务管理方各有优劣,编程事务管理灵活性较高,适用于复杂的事务场景,但需要开发人员手动编写大量的事务管理代码;声明式事务管理简化了开发工作,通过配置即可实现事务管理,但对于一些复杂的业务场景可能不够灵活。 总的来说,对于大部分应用场景而言,推荐使用声明式事务管理,可以减少重复代码的编写,提高开发效率。而在一些特殊的业务场景下,如需要动态控制事务的提交和回滚,或者需要手动处理一些特殊情况,可以考虑使用编程事务管理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值