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)。
相关推荐
武子康4 小时前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
舒一笑4 小时前
我的开源项目-PandaCoder迎来史诗级大更新啦
后端·程序员·intellij idea
@昵称不存在6 小时前
Flask input 和datalist结合
后端·python·flask
zhuyasen6 小时前
Go 分布式任务和定时任务太难?sasynq 让异步任务从未如此简单
后端·go
新world6 小时前
mybatis-plus从入门到入土(三):持久层接口之IService
mybatis
东林牧之6 小时前
Django+celery异步:拿来即用,可移植性高
后端·python·django
超浪的晨7 小时前
Java UDP 通信详解:从基础到实战,彻底掌握无连接网络编程
java·开发语言·后端·学习·个人开发
AntBlack7 小时前
从小不学好 ,影刀 + ddddocr 实现图片验证码认证自动化
后端·python·计算机视觉
Pomelo_刘金8 小时前
Clean Architecture 整洁架构:借一只闹钟讲明白「整洁架构」的来龙去脉
后端·架构·rust
双力臂4048 小时前
Spring Boot 单元测试进阶:JUnit5 + Mock测试与切片测试实战及覆盖率报告生成
java·spring boot·后端·单元测试