mybatisPlus一个事务中切换数据源概述

概述

在多数据源的配置下,业务中经常遇到在一个被本地事务包裹的save/edi方法中需要查询另一个数据源的数据;
直接查询会提示table不存在,这是因为一个事务和一个mysql连接是绑定的,mysql的连接背后包含了数据库信息,直接调用还是在当前连接上调用的;

这里可以利用事务的单一connection连接这个特性,曲线解决这个问题;

环境
mysql8
springboot2.7.4

方法

方法很简单,就是在查询另一个数据源时,开启一个新事务就行了


public class LogicDeleteTest {

    @Transactional
    public void asLinkDiscountServiceLogicDelete(){
        //获取aop代理类
        ((LogicDeleteTest)AopContext.currentProxy()).findDataFromOtherDataSource();
    }

    @Transactional(propagation = Propagation.REQUIRES_NEW)
    public Object findDataFromOtherDataSource(){
        return null;
    }

}

源码分析

spring的事务整体流程大致如下;
可以实际debug一波看下多数据源下,使用上述2个事务后spring对事务的执行流程;

  1. 获取事务的属性(@Transactional注解中的配置)
  2. 加载配置中的TransactionManager.
  3. 获取收集事务信息TransactionInfo
  4. 执行目标方法
  5. 出现异常,尝试处理。
  6. 清理事务相关信息
  7. 提交事务

简单起见可以从这个源码class方法中入手
org.springframework.transaction.interceptor.TransactionAspectSupport#invokeWithinTransaction

最后在这个方法中开启了新事务,并获取了一个新连接
org.springframework.jdbc.datasource.DataSourceTransactionManager#doBegin

再往下就是根据注解上的数据源name获取对应的数据源,获取到对应数据源后,之后的流程就和普通查询流程一样了
com.baomidou.dynamic.datasource.toolkit.DynamicDataSourceContextHolder#peek
com.baomidou.dynamic.datasource.DynamicRoutingDataSource#getDataSource

在这里插入图片描述

在这里插入图片描述

  • 7
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值