当前位置: 首页 > news >正文

springboot + mybatis 多数据源切换

参考的b站博主写的
配置文件:

spring:datasource:db1:jdbc-url: jdbc:mysql://localhost:3306/interview_database?useUnicode=true&characterEncoding=utf-8&useSSL=falseusername: rootpassword: 12345driver-class-name: com.mysql.cj.jdbc.Driverdb2:jdbc-url: jdbc:mysql://localhost:3306/cailu-family-manager?useUnicode=true&characterEncoding=utf-8&useSSL=falseusername: rootpassword: 12345driver-class-name: com.mysql.cj.jdbc.Driver

DataSourceChange.java 设定切换数据库的类,使用ThreadLocal


/*** @author HFQ* @version 1.0.0* @ClassName DataSourceChange.java* @Description 数据源切换* @createTime 2024年07月03日 22:56:00*/
public class DataSourceChange {private static final ThreadLocal<String> contextHolder = new ThreadLocal();// 设置默认数据库static {contextHolder.set("db1");}public static void setDB(String dbType){contextHolder.set(dbType);}public static String getDB(){return contextHolder.get();}
}

DynamicDataSource 类设置数据源,继承AbstractRoutingDataSource类基于查找键将getConnection()调用路由到各种目标DataSource之一的抽象DataSource实现。后者通常(但不一定)是通过一些线程绑定的事务上下文来确定的。

/*** @author HFQ* @version 1.0.0* @ClassName DynamicDataSource.java* @Description 设置数据源* @createTime 2024年07月03日 22:51:00*/
public class DynamicDataSource extends AbstractRoutingDataSource {@Overrideprotected Object determineCurrentLookupKey() {return DataSourceChange.getDB();}
}

DataSourceConfig类多数据源配置

/*** @author HFQ* @version 1.0.0* @ClassName DataSourceConfig.java* @Description 多数据源配置* @createTime 2024年07月03日 21:57:00*/
@Configuration
public class DataSourceConfig {/*** @ConfigurationProperties用的反射来做这个功能* @return*/@Bean(name = "db1")@ConfigurationProperties(prefix = "spring.datasource.db1")public DataSource db1(){return DataSourceBuilder.create().build();}@Bean(name = "db2")@ConfigurationProperties(prefix = "spring.datasource.db2")public DataSource db2(){return DataSourceBuilder.create().build();}@Bean(name = "dynamicDataSource")@Primarypublic DataSource dynamicDataSource(@Qualifier("db1")DataSource db1,@Qualifier("db2")DataSource db2){DynamicDataSource dynamicDataSource = new DynamicDataSource();// 设置默认数据源 这个代码有点重复了,因为我们在DataSourceChange类中已经设定了默认数据库dynamicDataSource.setDefaultTargetDataSource(db1);HashMap<Object, Object> objectObjectHashMap = new HashMap<>();objectObjectHashMap.put("db1", db1);objectObjectHashMap.put("db2", db2);dynamicDataSource.setTargetDataSources(objectObjectHashMap);return dynamicDataSource;}@Beanpublic PlatformTransactionManager transactionManager(@Qualifier("dynamicDataSource") DataSource dynamicDataSource){return new DataSourceTransactionManager(dynamicDataSource);}
}

@ConfigurationProperties(prefix = “spring.datasource.db1”)
在Spring Boot中,@ConfigurationProperties注解用于将外部的配置属性(如application.yml或application.properties文件中的属性)映射到一个Java类的字段中。当你创建DataSourceBuilder并调用build方法时,Spring Boot会自动注入这些配置属性(使用的反射完成)。

测试一下
测试代码:

@Testpublic void testDb1(){// tagsMapper使用的是db1的连接,testMapper使用的是db2连接ArrayList<String> strings = new ArrayList<>();strings.add("女性");strings.add("广州");for (Integer tagsByName : tagsMapper.findTagsByNames(strings)) {System.out.println(tagsByName);}// 切换到db2DataSourceChange.setDB("db2");List<Map<String, Object>> maps = testMapper.selectTest();for (Map<String, Object> map : maps) {System.out.println(map.get("account_name").toString());}}

然后, 既然是多数据源,那mapper.xml文件也需要分层
所以我的mapper文件夹是这样的
在这里插入图片描述
mapper-locations 使用逗号分隔
yml配置文件:

mybatis:mapper-locations: classpath*:/mapper/db1/*.xml,classpath*:/mapper/db2/*.xml

执行结果:
在这里插入图片描述

http://www.lryc.cn/news/392276.html

相关文章:

  • windows电脑网络重置后wifi列表消失怎么办?
  • Python + 在线 + 文生音,音转文(中文文本转为英文语音,语音转为中文文本)
  • 哏号分治,CF103D - Time to Raid Cowavans
  • 基于深度学习的图像背景剔除
  • Python使用(...)连接字符串
  • 鸿蒙:1.入门
  • 【matlab】智能优化算法——求解目标函数
  • 不改代码,实现web.config或app.config的连接字符串加密解密
  • Python创建MySQL数据库
  • 【C++】unordered系列容器的封装
  • matlab 超越椭圆函数图像绘制
  • 本地文件同步上传到Gitee远程仓库
  • RESTful Web 服务详解
  • 【ARMv8/v9 GIC 系列 5.3 -- 系统寄存器对中断的处理】
  • MUNIK解读ISO26262--系统架构
  • STM32第十五课:LCD屏幕及应用
  • Java--继承
  • Github与本地仓库建立链接、Git命令(或使用Github桌面应用)
  • c++之旅第十一弹——顺序表
  • 深入了解 PXE:定义、架构、原理、应用场景及常见命令体系
  • 《每天5分钟用Flask搭建一个管理系统》第9章:API设计
  • CCM的作用及原理
  • 10.09面试题目记录
  • 14-29 剑和诗人3 – 利用知识图谱增强 LLM 推理能力
  • 【代码大全2 选读】看看骨灰级高手消灭 if-else 逻辑的瑞士军刀长啥样
  • 深度学习 --- stanford cs231学习笔记八(训练神经网络之dropout)
  • 【C++】 解决 C++ 语言报错:Undefined Reference
  • 【博士每天一篇文献-算法】Adult neurogenesis acts as a neural regularizer
  • 在Spring Boot项目中引入本地JAR包的步骤和配置
  • Android Studio中使用命令行gradle查看签名信息