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)。
相关推荐
专注_每天进步一点点33 分钟前
idea 启动Springboot项目在编译阶段报错:java: OutOfMemoryError: insufficient memory
java·spring boot·intellij-idea
weixin_545019326 小时前
微信小程序智能商城系统(uniapp+Springboot后端+vue管理端)
spring boot·微信小程序·uni-app
IsPrisoner6 小时前
Go语言安装proto并且使用gRPC服务(2025最新WINDOWS系统)
开发语言·后端·golang
tan180°7 小时前
Linux进程信号处理(26)
linux·c++·vscode·后端·信号处理
一只码代码的章鱼8 小时前
Spring的 @Validate注解详细分析
前端·spring boot·算法
有梦想的攻城狮8 小时前
spring中的@MapperScan注解详解
java·后端·spring·mapperscan
柚个朵朵9 小时前
Spring的Validation,这是一套基于注解的权限校验框架
java·后端·spring
程序员小杰@9 小时前
【MCP教程系列】SpringBoot 搭建基于 Spring AI 的 SSE 模式 MCP 服务
人工智能·spring boot·spring
程序员buddha9 小时前
Spring & Spring Boot 常用注解整理
java·spring boot·spring