mysql多数据源事务_MybatisPlus多数据源及事务解决思路

关于多数据源解决方案

目前在SpringBoot框架基础上多数据源的解决方案大多手动创建多个DataSource,后续方案有三:

继承org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource,使用AOP切面注入相应的数据源 ,但是这种做法仅仅适用单Service方法使用一个数据源可行,如果单Service方法有多个数据源执行会造成误读。

通过DataSource配置 JdbcTemplateBean,直接使用 JdbcTemplate操控数据源。

分别通过DataSource创建SqlSessionFactory并扫描相应的Mapper文件和Mapper接口。

01834c0a0aeda3d9961781afed5c4cb2.png

MybatisPlus的多数据源

我通过阅读源码,发现MybatisPlus的多数据源解决方案正是AOP,继承了org.springframework.jdbc.datasource.AbstractDataSource,有自己对ThreadLocal的处理。通过注解切换数据源。也就是说,MybatisPlus只支持在单Service方法内操作一个数据源,毕竟官网都指明——“强烈建议只注解在service实现上”。

而后,注意看com.baomidou.dynamic.datasource.toolkit.DynamicDataSourceContextHolder,也就是MybatisPlus是如何切换数据源的。

重点看:

/**

* 为什么要用链表存储(准确的是栈)

*

 
 

* 为了支持嵌套切换,如ABC三个service都是不同的数据源

* 其中A的某个业务要调B的方法,B的方法需要调用C的方法。一级一级调用切换,形成了链。

* 传统的只设置当前线程的方式不能满足此业务需求,必须模拟栈,后进先出。

*

*/

private static final ThreadLocal> LOOKUP_KEY_HOLDER = new ThreadLocal() {

@Override

protected Object initialValue() {

return new ArrayDeque();

}

};

这段话翻译为大家都能懂得的意思就是**“可以同时操控多个数据源”**。那么,在MYSQL中,有语法为schemaName+. +tableName,如此一来就不会误走数据源了。

我继续看MybatisPlus是如何利用mybatis本身的ORM机制将实体类自动映射以及生成SQL语句的(这里插一句,MybatisPlus的源码易读懂,写的很不错)。无意看到了注解com.baomidou.mybatisplus.annotation.TableName中的schema,如果在

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值