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)。
相关推荐
Daybreak17 分钟前
Elasticsearch 里的索引和 Mapping,到底是什么关系?
后端
Lee川19 分钟前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
李小狼lee25 分钟前
深入浅出sse协议,用代码自己实现
后端
SamDeepThinking1 小时前
并发量就算只有2,该上锁还得上呀
java·后端·架构
永远不会的CC6 小时前
浙江华昱欣实习(4月23日~ 4月19日)
后端·学习
直奔標竿7 小时前
Java开发者AI转型第二十五课!Spring AI 个人知识库实战(四)——RAG来源追溯落地,拒绝AI幻觉
java·开发语言·人工智能·spring boot·后端·spring
嘟嘟MD7 小时前
程序员副业 | 2026年4月复盘
后端·创业
时空系7 小时前
认识Rust——我的第一个程序 Rust中文编程
开发语言·后端·rust