【SpringBoot DB 系列】Mybatis-Plus 多数据源配置
前面介绍了两种 Mybatis 的数据源配置,当然也少不了 mybatis-plus
MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,既然做增强,那多数据源这种硬性场景,肯定是有非常简单的解决方案的
本文将实例演示 Mybatis-Plus 多数据源的配置
I. 环境准备
1. 数据库相关
以 mysql 为例进行演示说明,因为需要多数据源,一个最简单的 case 就是一个物理库上多个逻辑库,本文是基于本机的 mysql 进行操作
创建数据库test
与 story
,两个库下都存在一个表money
(同名同结构表,但是数据不同哦)
1 | sql复制代码CREATE TABLE `money` ( |
2. 项目环境
本项目借助SpringBoot 2.2.1.RELEASE
+ maven 3.5.3
+ IDEA
进行开发
下面是核心的pom.xml
(源码可以再文末获取)
1 | xml复制代码<dependencies> |
配置文件信息application.yml
,请注意下面的写法格式,如有疑问可以参考官方教程
1 | yaml复制代码spring: |
II. 项目演示
本文主要参考自 Mybatis-Plus 官方教程,如后续版本有啥变动,请以官方说明为准
mp.baomidou.com/guide/dynam…
1. 实体类
mybatis-plus 可以借助插件实现自动生成相应的代码,我们这里简单自主实现测试 demo,因为两个数据库中表结构完全一致,所以只需要一个 Entity
1 | java复制代码@Data |
2. Mapper 接口
数据库操作定义接口MoneyMapper
1 | java复制代码public interface MoneyMapper extends BaseMapper<MoneyPo> { |
对应的 xml 文件resources/mapper/money-mapper.xml
1 | xml复制代码<?xml version="1.0" encoding="UTF-8"?> |
3. Service 接口与实现
因为两张表,所以我们可以定义一个接口,两个不同的实现
1 | java复制代码public interface MoneyService extends IService<MoneyPo> { |
请注意上面 Service 的注解@DS
,value 为前面数据源配置文件中的 key(spring.datasource.dynamic.datasource
下面的story
+ test
)
这个注解可以放在类上也可以放在方法上,方法上的优先级 > 类,所以上面的两个 Service 实现可以改成一个
1 | java复制代码@Service |
4. 测试
为简单起见,直接在启动类中添加写上测试代码
1 | java复制代码@SpringBootApplication |
II. 其他
0. 项目
相关博文
- 【DB 系列】Mybatis 基于 AbstractRoutingDataSource 与 AOP 实现多数据源切换
- 【DB 系列】Mybatis 多数据源配置与使用
- 【DB 系列】JdbcTemplate 之多数据源配置与使用
- 【DB 系列】Mybatis-Plus 代码自动生成
- 【DB 系列】MybatisPlus 整合篇
- 【DB 系列】Mybatis+注解整合篇
- 【DB 系列】Mybatis+xml 整合篇
源码
1. 一灰灰 Blog
尽信书则不如,以上内容,纯属一家之言,因个人能力有限,难免有疏漏和错误之处,如发现 bug 或者有更好的建议,欢迎批评指正,不吝感激
下面一灰灰的个人博客,记录所有学习和工作中的博文,欢迎大家前去逛逛
- 一灰灰 Blog 个人博客 blog.hhui.top
- 一灰灰 Blog-Spring 专题博客 spring.hhui.top
- 微信公众号: 一灰灰blog
本文转载自: 掘金