springboot mybatisplus 多数据源_【SpringBoot DB 系列】MybatisPlus 多数据源配置

c80cf2f58913b313d24477b74dc24c15.png

【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 进行操作

创建数据库teststory,两个库下都存在一个表money (同名同结构表,但是数据不同哦)

CREATE TABLE `money` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(20) NOT NULL DEFAULT '' COMMENT '用户名',
  `money` int(26) NOT NULL DEFAULT '0' COMMENT '钱',
  `is_deleted` tinyint(1) NOT NULL DEFAULT '0',
  `create_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `update_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  PRIMARY KEY (`id`),
  KEY `name` (`name`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;
ccfa9239bb67f9aea592ff03b704d306.png

2. 项目环境

本项目借助SpringBoot 2.2.1.RELEASE + maven 3.5.3 + IDEA进行开发

下面是核心的pom.xml(源码可以再文末获取)

<dependencies>
    <dependency>
        <groupId>mysqlgroupId>
        <artifactId>mysql-connector-javaartifactId>
    dependency>

    <dependency>
        <groupId>com.baomidougroupId>
        <artifactId>dynamic-datasource-spring-boot-starterartifactId>
        <version>3.3.1version>
    dependency>

    <dependency>
        <groupId>com.baomidougroupId>
        <artifactId>mybatis-plus-boot-starterartifactId>
        <version>3.3.1version>
    dependency>
dependencies>

配置文件信息application.yml,请注意下面的写法格式,如有疑问可以参考官方教程

spring:
  datasource:
    dynamic:
      primary: story #设置默认的数据源或者数据源组,默认值即为master
      strict: false  #设置严格模式,默认false不启动. 启动后在未匹配到指定数据源时候会抛出异常,不启动则使用默认数据源.
      datasource:
        story:
          driver-class-name: com.mysql.cj.jdbc.Driver
          url: jdbc:mysql://127.0.0.1:3306/story?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
          username: root
          password:
        test:
          driver-class-name: com.mysql.cj.jdbc.Driver
          url: jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
          username: root
          password:

II. 项目演示

本文主要参考自 Mybatis-Plus 官方教程,如后续版本有啥变动,请以官方说明为准https://mp.baomidou.com/guide/dynamic-datasource.html#%E6%96%87%E6%A1%A3-documentation

1. 实体类

mybatis-plus 可以借助插件实现自动生成相应的代码,我们这里简单自主实现测试 demo,因为两个数据库中表结构完全一致,所以只需要一个 Entity

@Data
@Accessors(chain = true)
@TableName(value = "money")
public class MoneyPo {
    /**
     * 指定自增策略
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;

    private String name;

    private Long money;

    @TableField("is_deleted")
    private Integer isDeleted;

    @TableField(value = "create_at")
    private Timestamp createAt;

    @TableField(value = "update_at")
    private Timestamp updateAt;
}

2. Mapper 接口

数据库操作定义接口MoneyMapper

public interface MoneyMapper extends BaseMapper<MoneyPo> {
}

对应的 xml 文件resources/mapper/money-mapper.xml

<?xml  version="1.0" encoding="UTF-8"?>
mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.git.hui.boot.multi.datasource.mapper.MoneyMapper">
mapper>

3. Service 接口与实现

因为两张表,所以我们可以定义一个接口,两个不同的实现

public interface MoneyService extends IService<MoneyPo> {
}

@Service
@DS("story")
public class StoryMoneyServiceImpl extends ServiceImpl<MoneyMapper, MoneyPo> implements MoneyService {
}

@Service
@DS("test")
public class TestMoneyServiceImpl extends ServiceImpl<MoneyMapper, MoneyPo> implements MoneyService {
}

请注意上面 Service 的注解@DS,value 为前面数据源配置文件中的 key(spring.datasource.dynamic.datasource下面的story + test)

这个注解可以放在类上也可以放在方法上,方法上的优先级 > 类,所以上面的两个 Service 实现可以改成一个

@Service
public class MoneyServiceImpl extends ServiceImpl<MoneyMapper, MoneyPo> implements MoneyService {

    @DS("story")
    public List findByStoryIds(Collection ids) {
        return baseMapper.selectBatchIds(ids);
    }

    @DS("test")
    public List findByTestIds(Collection ids) {
        return baseMapper.selectBatchIds(ids);
    }
}

4. 测试

为简单起见,直接在启动类中添加写上测试代码

@SpringBootApplication
@MapperScan("com.git.hui.boot.multi.datasource.mapper")
public class Application {

    public Application(TestMoneyServiceImpl testMoneyService, StoryMoneyServiceImpl storyMoneyService) {
        List moneyPoList = testMoneyService.listByIds(Arrays.asList(1, 1000));
        System.out.println(moneyPoList);
        System.out.println("--------------");
        moneyPoList = storyMoneyService.listByIds(Arrays.asList(1, 1000));
        System.out.println(moneyPoList);
    }public static void main(String[] args) {
        SpringApplication.run(Application.class);
    }
}
faa0cd37713615e16f1fcd458dcd3ed0.png

II. 其他

0. 项目

相关博文

  • 【SpringBoot DB 系列】Mybatis 基于 AbstractRoutingDataSource 与 AOP 实现多数据源切换
  • 【SpringBoot DB 系列】Mybatis 多数据源配置与使用
  • 【SpringBoot DB 系列】JdbcTemplate 之多数据源配置与使用
  • 【SpringBoot DB 系列】Mybatis-Plus 代码自动生成
  • 【SpringBoot DB 系列】MybatisPlus 整合篇
  • 【SpringBoot DB 系列】Mybatis+注解整合篇
  • 【SpringBoot DB 系列】Mybatis+xml 整合篇

源码

  • 工程:https://github.com/liuyueyi/spring-boot-demo
  • 源码: https://github.com/liuyueyi/spring-boot-demo/tree/master/spring-boot/109-multi-datasource-mybatis-plus

1. 一灰灰 Blog

尽信书则不如,以上内容,纯属一家之言,因个人能力有限,难免有疏漏和错误之处,如发现 bug 或者有更好的建议,欢迎批评指正,不吝感激

下面一灰灰的个人博客,记录所有学习和工作中的博文,欢迎大家前去逛逛

  • 一灰灰 Blog 个人博客 https://blog.hhui.top
  • 一灰灰 Blog-Spring 专题博客 http://spring.hhui.top
5f429778ab77efe0eaf713fdfe1f0509.png
一灰灰blog
SpringBoot结合MyBatisPlus配置多数据源的示例代码主要包括以下几个步骤[^1][^2]: 1. **配置文件信息**: 在`application.properties`或`application.yml`中添加多数据源配置,例如: ```properties # 主数据源配置 spring.datasource.master.url=jdbc:mysql://localhost:3306/master_db spring.datasource.master.username=root spring.datasource.master.password=master_password # 备份数据源配置 spring.datasource_slave.url=jdbc:mysql://localhost:3306/backup_db spring.datasource_slave.username=root spring.datasource_slave.password=backup_password # 数据源切换相关配置 spring.aop.auto=true data-source-switch.datasource-names=master,slave ``` 2. **多数据源配置类**: 创建一个`DataSourceSwitch`配置类,通常会继承`AbstractRoutingDataSource`或自定义实现: ```java import org.springframework.jdbc.datasource.lookup.DataSourceLookupFailureException; import org.springframework.jdbc.datasource.lookup.DataSourceUtils; public class DataSourceSwitch extends AbstractRoutingDataSource { private String dataSourceName; @Override protected Object determineCurrentLookupKey() { return dataSourceName; } // 在需要切换数据源的地方调用此方法 public void switchDataSource(String dataSourceName) { this.dataSourceName = dataSourceName; try { setTargetDataSource(DataSourceUtils.getConnection(dataSourceName)); } catch (DataSourceLookupFailureException e) { throw new RuntimeException("切换数据源失败", e); } } } ``` 3. **动态数据源切换**: 使用Spring AOP在需要访问数据库的地方自动切换数据源,比如在Repository接口上添加切面: ```java @Aspect @Configuration public class DataSourcesAspect { @Autowired private DataSourceSwitch dataSourceSwitch; @Before("execution(* com.example.repository.*.*(..))") public void switchDataSource(JoinPoint joinPoint) { MethodSignature signature = (MethodSignature) joinPoint.getSignature(); String methodName = signature.getMethod().getName(); dataSourceSwitch.switchDataSource(methodName.equals("master") ? "master" : "slave"); } } ``` 4. **MyBatisPlus配合**: 在MyBatisPlus的全局配置类中,注入数据源,这样MyBatisPlus就会自动使用当前的数据源: ```java @Configuration public class GlobalConfig { @Autowired private DataSourceSwitch dataSourceSwitch; @Bean public GlobalConfig globalConfig() { GlobalConfig config = new GlobalConfig(); config.setDataSource(dataSourceSwitch.getTargetDataSource()); return config; } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值