首先,既然是多数据源,那么我们就先看下数据源怎么配置的:

javaconfig类似下面这样:

MapperScan注解常用配置如下:

basePackages:Base packages to scan for MyBatis interfaces,也就是mapper接口所在包名

annotationClass:This property specifies the annotation that the scanner will search for,

也就是只扫描指定包下的指定注解作为mapper,通常为org.apache.ibatis.annotations.Mapper

markerInterface:This property specifies the parent that the scanner will search for,只扫描指定包下指定父接口的子接口作为mapper

sqlSessionTemplateRef:指定这组mapper关联的sqlSessionTemplate

sqlSessionFactoryRef:指定这组mapper关联的sqlSessionFactory

那么,问题来了,annotationClass,markerInterface都配置了或者都不配置会怎样?在org.mybatis.spring.annotation.MapperScannerRegistrar.registerBeanDefinitions中调用的org.mybatis.spring.mapper.ClassPathMapperScanner.registerFilters()代码如下:

一幕了然,如果都配置了,最终的mapper会是两者匹配的合集;如果都不配置,那么,最终的mapper会是basePackages下所有任意接口。

使用地方在org.springframework.context.annotation.ClassPathScanningCandidateComponentProvider.isCandidateComponent:

还有一个问题,sqlSessionTemplateRef和sqlSessionFactoryRef同时都配置了会怎样?或者不配置呢?

通常,如果只有一个sqlSessionFactory时是不需要配置的,只有容器中有多个时才需要指定一个。

如果都配置了呢?请看下面分析:

org.mybatis.spring.mapper.ClassPathMapperScanner.processBeanDefinitions(Set<BeanDefinitionHolder>)中处理每一个之前扫描mapper生成的BeanDefinition时,会给每一个BeanDefinition设置sqlSessionFactory,如下:

看到log没,很清楚:Cannot use both: sqlSessionTemplate and sqlSessionFactory together. sqlSessionFactory is ignored.

看完mapper的处理,再来看关联的sqlSessionFactory:

根据指定数据源类型利用org.springframework.boot.jdbc.DataSourceBuilder创建dataSource,目前主流的是使用阿里开源的Druid数据库连接池作为数据源:

sqlSessionFactory创建:

通过SqlSessionFactoryBean关联dataSource和MapperXML,再通过@MapperScan关联sqlSessionFactory和mapper接口

至此,单个数据源创建算是完成了。如题,多数据源怎么办?

方法一,手动配置多个dataSource,并在@MapperScan关联不同的sqlSessionFactory和mapper接口。

方法二,动态数据源,继承org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource,重写determineTargetDataSource方法,从targetDataSources中获取对应数据源操作数据库,通常在前面业务代码根据具体怎样的情况选择怎样的dataSource,然后通过设置ThreadLocal变量,这里获取变量信息来返回对应数据源。切入业务逻辑可以通过aop切面从dao层方法名入手,也可以通过mybatis的拦截器获取sql信息和入参决定选择哪个数据源。

PS:如果是读写分离,通常情况下主库读写权限,从库只读权限,事务DataSourceTransactionManager配置在主库的dataSource上,@Transactional会自动从配置事务的dataSource中获取连接。

springboot+mybatis多数据源的更多相关文章

  1. spring-boot (四) springboot+mybatis多数据源最简解决方案

    学习文章来自:http://www.ityouknow.com/spring-boot.html 配置文件 pom包就不贴了比较简单该依赖的就依赖,主要是数据库这边的配置: mybatis.confi ...

  2. springboot + mybatis + 多数据源

    此文已由作者赵计刚薪授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验 在实际开发中,我们一个项目可能会用到多个数据库,通常一个数据库对应一个数据源. 代码结构: 简要原理: 1) ...

  3. 第九章 springboot + mybatis + 多数据源 (AOP实现)

    在第八章 springboot + mybatis + 多数据源代码的基础上,做两点修改 1.ShopDao package com.xxx.firstboot.dao; import org.spr ...

  4. 【第九章】 springboot + mybatis + 多数据源 (AOP实现)

    在第八章 springboot + mybatis + 多数据源代码的基础上,做两点修改 1.ShopDao package com.xxx.firstboot.dao; import org.spr ...

  5. springboot mybatis 多数据源配置

    首先导入mybatis等包,这里就不多说. 下面是配置多数据源和mybatis,每个数据源对应一套mybatis模板 数据源1: package com.aaaaaaa.config.datasour ...

  6. 第八章 springboot + mybatis + 多数据源(转载)

    本篇博客转发自:http://www.cnblogs.com/java-zhao/p/5413845.html 在实际开发中,我们一个项目可能会用到多个数据库,通常一个数据库对应一个数据源. 代码结构 ...

  7. 【第八章】 springboot + mybatis + 多数据源

    在实际开发中,我们一个项目可能会用到多个数据库,通常一个数据库对应一个数据源. 代码结构: 简要原理: 1)DatabaseType列出所有的数据源的key---key 2)DatabaseConte ...

  8. 第八章 springboot + mybatis + 多数据源2(解决循环引用)

    解决了循环引用 1.application.properties #the first datasource jdbc.names:1,2 jdbc1.driverClassName = com.my ...

  9. spring boot(七):springboot+mybatis多数据源最简解决方案

    说起多数据源,一般都来解决那些问题呢,主从模式或者业务比较复杂需要连接不同的分库来支持业务.我们项目是后者的模式,网上找了很多,大都是根据jpa来做多数据源解决方案,要不就是老的spring多数据源解 ...

  10. SpringBoot ( 七 ) :springboot + mybatis 多数据源最简解决方案

    说起多数据源,一般都来解决那些问题呢,主从模式或者业务比较复杂需要连接不同的分库来支持业务.我们项目是后者的模式,网上找了很多,大都是根据jpa来做多数据源解决方案,要不就是老的spring多数据源解 ...

随机推荐

  1. 6_13古代象形符号(UVa1103)<图的连通块的应用>

    给出一幅黑白图像,每行相邻的四个点压缩成一个十六进制的字符.然后还有题中图示的6中古老的字符,按字母表顺序输出这些字符的标号. 输出说明:For each test case, display its ...

  2. 第二十四篇 玩转数据结构——队列(Queue)

          1.. 队列基础 队列也是一种线性结构: 相比数组,队列所对应的操作数是队列的子集: 队列只允许从一端(队尾)添加元素,从另一端(队首)取出元素: 队列的形象化描述如下图: 队列是一种先进 ...

  3. 查询 keystore文件的签名信息

    需要安装jdk 在安装 jdk的/bin文件夹下 keytool -v -list -keystore [keystore文件的路径]

  4. 自己centos7成功的修改了主机名(记录了该改哪些文件)

    1.更改/etc/hosts 方法(1)可以直接的去更改这个文件,更改的格式:直接vi编辑器打开,之后直接写上自己想要的主机名字就好,不用写成键值对的形式 [root@localhost etc]# ...

  5. mongodb的一些操作

    插入: db.inventory.insert( { _id: 10, type: "misc", item: "card", qty: 15 } ) db.i ...

  6. jmeter 进行websocket数据帧过大导致code 1009

    Response message: Received: Close frame with status code 1009 and close reason 'No async message sup ...

  7. linux sftp 和scp 运用

    Linux scp命令: Upload  to remote :复制本地文件到远程 Part1: Scp  -P port  local_file  remote_user@remote_ip:rem ...

  8. Eclipse安装配置java项目

    设置智能提示

  9. php头像上传插件

    最近找到了一个比较简单实用的php头像上传插件,兼容IE8及以上等主流浏览器,分享给大家.效果如下: 1.首页效果图:默认显示默认图片. 2.点击图片(拥有裁剪框,可以拖动.缩放.裁剪头像等功能,注意 ...

  10. scipy1.3.0开始被弃用的imread,imresize,如何代替

    scipy1.3.0开始被弃用的imread,imresize,如何代替 SciPy最新官方文档的说明(20190730): Functions from scipy.interpolate (spl ...