Spring boot + mybatis plus 多数据源

有参照链接:SpringBoot配置多数据源的一款框架(dynamic-datasource-spring-boot-starter) - 编程宝库

场景:A公司为总公司,B公司为分公司,B公司上传的数据需要保存到A公司中。

application.yml的配置

java 复制代码
spring:
  datasource:
    dynamic:
      primary: mysql1
      strict: false
      datasource:
        mysql1:
          driver-class-name: com.mysql.cj.jdbc.Driver
          url: jdbc:mysql://127.0.0.1:3306/bn?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai&useSSL=false&allowMultiQueries=true
          username: root
          password: mima123
          type: com.alibaba.druid.pool.DruidDataSource
          druid:
            initial-size: 5
            min-idle: 5
            max-active: 20
            max-wait: 60000
            time-between-eviction-runs-millis: 60000
            min-evictable-idle-time-millis: 300000
            validation-query: SELECT 1 FROM DUAL
            test-while-idle: true
            test-on-borrow: false
            test-on-return: false
        mysql2:
          driver-class-name: com.mysql.cj.jdbc.Driver
          url: jdbc:mysql://127.0.0.1:3306/bn_1?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai&useSSL=false&allowMultiQueries=true
          username: root
          password: mima123
          type: com.alibaba.druid.pool.DruidDataSource
          druid:
            initial-size: 5
            min-idle: 5
            max-active: 20
            max-wait: 60000
            time-between-eviction-runs-millis: 60000
            min-evictable-idle-time-millis: 300000
            validation-query: SELECT 1 FROM DUAL
            test-while-idle: true
            test-on-borrow: false
            test-on-return: false

serviceImpl业务代码

java 复制代码
    @Override
    public List<BnUser> getBnUser1() {
        QueryWrapper<BnUser> b = new QueryWrapper<>();
        b.eq("user_name","common");
        List<BnUser> bnUser = bnUserMapper.selectList(b);
        if (bnUser != null){
            return bnUser;
        }
        return null;
    }

    //@DS("mysql2")
    @Override
    public List<BnUser> getBnUser2() {
        QueryWrapper<BnUser> b = new QueryWrapper<>();
        b.eq("user_name","common1");
        List<BnUser> bnUser = bnUserMapper.selectList(b);
        if (bnUser != null){
            return bnUser;
        }
        return null;
    }

controller的结果

java 复制代码
    @GetMapping("testMoreData")
    public void testMoreData(){
        List<BnUser> bnUser1 = bnUserService.getBnUser1();
        System.out.println("bnuser1 ===== "+bnUser1);

        List<BnUser> bnUser21 = bnUserService.getBnUser2();
        System.out.println("bnuser2 ====== "+bnUser21);


        /*DynamicDataSourceContextHolder.push("mysql1");
        List<BnUser> users = bnUserService.getBnUser1();
        DynamicDataSourceContextHolder.poll();
        //这里切换了数据源
        DynamicDataSourceContextHolder.push("mysql2");
        List<BnUser> bnUser2 = bnUserService.getBnUser2();
        DynamicDataSourceContextHolder.poll();
        System.out.println(users + "=====" + bnUser2);*/
    }

显示结果:

  1. serviceImpl文件并未打开 @DS -> bnuser1 有数据(mysql1);bnuser2 没有数据。
  2. serviceImpl文件并未打开 @DS -> controller中的注释打开 -> users 有数据(mysql1);bnUser2 有数据(mysql2)。
  3. serviceImpl文件打开 @DS -> bnuser1 有数据(mysql1);bnuser2有数据(mysql2)。
相关推荐
郑祎亦12 分钟前
Spring Boot 项目 myblog 整理
spring boot·后端·java-ee·maven·mybatis
本当迷ya25 分钟前
💖2025年不会Stream流被同事排挤了┭┮﹏┭┮(强烈建议实操)
后端·程序员
计算机毕设指导61 小时前
基于 SpringBoot 的作业管理系统【附源码】
java·vue.js·spring boot·后端·mysql·spring·intellij-idea
paopaokaka_luck2 小时前
[371]基于springboot的高校实习管理系统
java·spring boot·后端
捂月3 小时前
Spring Boot 深度解析:快速构建高效、现代化的 Web 应用程序
前端·spring boot·后端
瓜牛_gn3 小时前
依赖注入注解
java·后端·spring
Estar.Lee3 小时前
时间操作[取当前北京时间]免费API接口教程
android·网络·后端·网络协议·tcp/ip
喜欢猪猪3 小时前
Django:从入门到精通
后端·python·django
一个小坑货3 小时前
Cargo Rust 的包管理器
开发语言·后端·rust
bluebonnet274 小时前
【Rust练习】22.HashMap
开发语言·后端·rust