java项目内@Transactional与@TargetDataSource同时出现在一个方法内会无法切换数据源

文章描述了一个在处理多个接口查询并插入数据到中间库时遇到的问题。最初,由于其中一个方法添加了@Transactional注解,导致性能下降。在去除该注解后,系统的运行效率显著提升。问题的排查过程中涉及了JPA的使用、Mapper、实体类和服务层的检查。
摘要由CSDN通过智能技术生成
有三个对外接口 查询之后把数据插入到中间库去
另外两个单独的接口 只有一个插入语句 也没加Transactional注解

一开始还以为是jpa写法影响 光注重里面 重新检查mapper、实体类、serveice

最后看到这方法头  因这个表插入四张表  所以加的Transactional 
去掉 Transactional 之后立马嘎嘎棒了。。。

在这里插入图片描述

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
如果一个方法需要调用多个使用不同数据方法,并且这些方法需要在同一个事务中执行,可以使用 `@Transactional` 注解来实现。 在使用 `@Transactional` 注解时,需要指定要使用的事务管理器的名称。可以通过在方法上使用 `@Transactional` 注解,并指定要使用的事务管理器的名称,来实现在同一个事务中执行多个使用不同数据方法。 例如,假设有两个方法,分别位于不同的服务中,需要在同一个事务中执行: ```java @Service public class ServiceA { @Autowired private ServiceB serviceB; @Autowired @Qualifier("primaryTransactionManager") private PlatformTransactionManager primaryTransactionManager; @Autowired @Qualifier("secondaryTransactionManager") private PlatformTransactionManager secondaryTransactionManager; @Transactional(value = "chainedTransactionManager") // 事务注解,指定使用链式事务管理器 public void doSomethingInBothDataSources() { // 在第一个数据上执行一些操作 // ... // 在第二个数据上执行一些操作 serviceB.doSomethingInSecondaryDataSource(); // 在第一个数据上继续执行一些操作 // ... } @Transactional(value = "primaryTransactionManager") // 事务注解,指定使用第一个数据的事务管理器 public void doSomethingInPrimaryDataSource() { // 在第一个数据上执行一些操作 // ... } } ``` 在上面的示例中,`ServiceA` 类中定义了两个方法,其中一个需要在两个不同的数据上执行一些操作。使用 `@Transactional` 注解时,通过指定事务管理器的名称来决定使用哪个数据的事务管理器。在这个例子中,使用了一个名为 `chainedTransactionManager` 的链式事务管理器,该管理器将两个数据的事务管理器连接在一起,以实现在同一个事务中执行多个使用不同数据方法。 需要注意的是,在同一个事务中执行多个不同数据方法时,需要确保这些方法都在同一个线程中执行。如果这些方法在不同的线程中执行,则无法在同一个事务中执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

boJIke

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值