下面只简单说了下实现思路 具体代码就不贴了 自行去下载代码看即可
这种方式方便后期扩展
Gitee代码地址(在master分支) https://gitee.com/deepjava/multiple-data-source.git
实现思路:
先配置好多个数据源注入容器, 在生成connection 对象之前 使用自定义注解动态切换数据源 如果方法上有事务需要同时保证切换数据源操作在开启事务操作之前,这样才能保证数据源成功切换。
注意:数据源切换后的事务问题处理
AOP可以触发数据源字符串的切换,这个没问题数据源真正切换的关键是 AbstractRoutingDataSource 的 determineCurrentLookupKey() 被调用,此方法是在open connection时触发,事务是在connection层面管理的,启用事务后,一个事务内部的connection是复用的,所以就算AOP切了数据源字符串,但是数据源并不会被真正修改
在事务开启后,数据源就不能再进行随意切换了,也就是说,一个事务对应一个数据源。那么传统的Spring管理事务是放在Service业务层操作的,所以更换数据源的操作要放在这个操作之前进行。
有两种方式解决:
方式一:把切换数据源的注解放在Controller层方法上或者把事务注解放到Dao层方法上,不推荐。
方式二:在事务方法外层再套一个方法专门负责切换数据源 并且负责使用代理对象调用事务方法,代码中目前使用这种方式处理,反正也是够奇葩的。 (如果有更好的处理方式 能让自定义注解在 开启事务注解之前执行 请留言 )
这种方式配置比较简单 用起来也省心 就是每次添加数据源的时候麻烦些
Gitee代码地址(在type_two分支) https://gitee.com/deepjava/multiple-data-source.git
思路: 简单直接, 相当于有几个数据源就加载几个mybatis框架, 通过设置mapper路径 执行对应路径的mapper方法时 就会使用对应的数据源,需要特别注意 默认数据源之外的 数据源 如果要开启事务 一定要使用
@Transactional(transactionManager = “该数据源对应的事务管理器名称”, rollbackFor = Exception.class)