Spring Boot 实现数据源动态切换的最佳姿势!
创作时间:
作者:
@小白创作中心
Spring Boot 实现数据源动态切换的最佳姿势!
引用
CSDN
1.
https://blog.csdn.net/weixin_45334346/article/details/145460785
在Spring Boot项目中,有时需要根据不同的业务场景切换不同的数据源。本文将详细介绍如何实现数据源的动态切换,包括数据库准备、工程环境配置以及动态数据源的具体实现方法。
2.1、数据库准备
首先,我们需要创建两个数据库:
- db_test_1
- db_test_2
在db_test_1数据库中创建一张用户表,脚本如下:
在db_test_2数据库中创建另一张账户表,脚本如下:
2.2、工程环境准备
在pom.xml文件中添加相关的依赖包,示例如下:
<!--spring boot核心-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<!--spring boot 测试-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--mysql 驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!-- druid -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.10</version>
</dependency>
<!--mybatis-->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.0.0</version>
</dependency>
<!--aspectj 注解代理-->
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
</dependency>
2.3、编写动态数据源
2.3.1、创建动态数据源服务类
首先,创建一个DynamicDataSource类,并继承AbstractRoutingDataSource抽象类,同时重写determineCurrentLookupKey()方法,代码示例如下:
2.3.2、创建动态数据源缓存类
创建一个DataSourceContextHolder类,用于缓存数据源,同时需要确保线程环境下安全
package com.example.dynamic.datasource.config;
public class DataSourceContextHolder {
/**
* 设置线程独立变量,用于存储数据源唯一标记
*/
private static final ThreadLocal<String> contextHolder = new ThreadLocal<>();
public static void setDataSourceKey(String key) {
contextHolder.set(key);
}
public static String getDataSourceKey() {
return contextHolder.get();
}
public static void clearDataSourceKey() {
contextHolder.remove();
}
}
热门推荐
解锁英语学习之门:探索通用高效学习策略
5个对葡萄酒品质影响最大的地理因素
【肿瘤患者福音】影像“靶向”追踪肿瘤,“在线四维影像引导”让放疗更精准
连喝8包板蓝根致病,医生紧急提醒:这些人群慎用!
在数据库中如何判断依赖
Excel 如何复制公式,向下复制一列而不改变引用
南师大学子走进无锡惠山古镇助力非遗传承
猪前脚和后脚的区别
人工智能如何重塑教育?
如何巧妙表达离职原因:真实、积极、简洁的写作技巧分享
高纯度氢氧化钙储存与运输方法及注意事项
电动车防晕车技术成新战场:舒适性体验成市场突围关键
高中体育成绩不达标,会影响惠州艺术生们大学录取吗?
钾离子测定全解析:作用、检测与补钾指南
清华大学实践队聚焦智慧医疗与养老,挖掘AI社会治理新潜能
格局重塑:AI对全球和我国社会经济影响与发展趋势解析
成年人抑郁症的症状表现有哪些
哪些人不宜吃米酒
沃柑上火还是降火?晚上能吃吗?专家来解答
海山公园:自然与休闲的完美结合
一元二次不等式的解法步骤 例题及答案
SVG是什么格式?一文带你弄清
IgA肾病怎么确诊
折叠滤芯:净水领域的科技结晶
摇钱树的花语与文化象征(富贵)
怎样使头发变黑
80后管理者应该如何与90后沟通,效率高同时有效果
怎样维持夫妻关系
电车“晕电”现象的详细分析
怀孕、哺乳期间可以接受放射诊断和治疗吗?