多数据源问题很常见,例如读写分离数据库配置。

原来的项目出现了新需求,局方要求新增某服务器用以提供某代码,涉及到多数据源的问题。
研究成果如下:
1、首先配置多个datasource
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="net.sourceforge.jtds.jdbc.Driver">
</property>
<property name="url" value="jdbc:jtds:sqlserver://10.82.81.51:1433;databaseName=standards">
</property>
<property name="username" value="youguess"></property>
<property name="password" value="youguess"></property>
</bean>
<bean id="dataSource2" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="net.sourceforge.jtds.jdbc.Driver">
</property>
<property name="url" value="jdbc:jtds:sqlserver://10.82.81.52:1433;databaseName=standards">
</property>
<property name="username" value="youguess"></property>
<property name="password" value="youguess"></property>
</bean>
2、写一个DynamicDataSource类继承AbstractRoutingDataSource,并实现determineCurrentLookupKey方法
package com.standard.core.util;
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
public class DynamicDataSource extends AbstractRoutingDataSource {
@Override
protected Object determineCurrentLookupKey() {
return CustomerContextHolder.getCustomerType();
}
}
3、利用ThreadLocal解决线程安全问题
package com.standard.core.util;
public class CustomerContextHolder {
public static final String DATA_SOURCE_A = "dataSource";
public static final String DATA_SOURCE_B = "dataSource2";
private static final ThreadLocal<String> contextHolder = new ThreadLocal<String>();
public static void setCustomerType(String customerType) {
contextHolder.set(customerType);
}
public static String getCustomerType() {
return contextHolder.get();
}
public static void clearCustomerType() {
contextHolder.remove();
}
}
4、数据源配置
<bean id="dynamicDataSource" class="com.standard.core.util.DynamicDataSource" >
<property name="targetDataSources">
<map key-type="java.lang.String">
<entry value-ref="dataSource" key="dataSource"></entry>
<entry value-ref="dataSource2" key="dataSource2"></entry>
</map>
</property>
<property name="defaultTargetDataSource" ref="dataSource" >
</property>
</bean>
5、在DAOImpl中切换数据源
复制代码 代码如下:
CustomerContextHolder.setCustomerType(CustomerContextHolder.DATA_SOURCE_B);
搞定!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# spring动态切换数据源
# spring
# 多数据源切换
# spring切换数据源
# Spring AbstractRoutingDatasource 动态数据源的实例讲解
# 浅谈利用Spring的AbstractRoutingDataSource解决多数据源的问题
# Spring(AbstractRoutingDataSource)实现动态数据源切换示例
# 使用Spring的AbstractRoutingDataSource实现多数据源切换示例
# Spring多租户数据源管理 AbstractRoutingDataSour
# 多个
# 涉及到
# 大家多多
# 出现了
# sqlserver
# url
# sourceforge
# net
# jtds
# Driver
# jdbc
# DynamicDataSource
# determineCurrentLookupKey
# AbstractRoutingDataSource
# standards
# databaseName
# username
# password
# youguess
# brush
相关文章:
建站之星代理如何优化在线客服效率?
专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?
c# await 一个已经完成的Task会发生什么
网站制作的步骤包括,正确网址格式怎么写?
香港服务器WordPress建站指南:SEO优化与高效部署策略
再谈Python中的字符串与字符编码(推荐)
php json中文编码为null的解决办法
红河网站制作公司,红河事业单位身份证如何上传?
免费ppt制作网站,有没有值得推荐的免费PPT网站?
中山网站推广排名,中山信息港登录入口?
常州企业网站制作公司,全国继续教育网怎么登录?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
建站之星安装失败:服务器环境不兼容?
西安大型网站制作公司,西安招聘网站最好的是哪个?
高性能网站服务器部署指南:稳定运行与安全配置优化方案
北京建设网站制作公司,北京古代建筑博物馆预约官网?
网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?
jQuery 常见小例汇总
C#怎么创建控制台应用 C# Console App项目创建方法
建站主机选哪家性价比最高?
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
企业网站制作公司网页,推荐几家专业的天津网站制作公司?
制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?
微信小程序 input输入框控件详解及实例(多种示例)
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
制作门户网站的参考文献在哪,小说网站怎么建立?
北京制作网站的公司,北京铁路集团官方网站?
小型网站制作HTML,*游戏网站怎么搭建?
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
建站之星云端配置指南:模板选择与SEO优化一键生成
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
学校免费自助建站系统:智能生成+拖拽设计+多端适配
Swift中swift中的switch 语句
陕西网站制作公司有哪些,陕西凌云电器有限公司官网?
教程网站设计制作软件,怎么创建自己的一个网站?
网站制作公司,橙子建站是合法的吗?
如何挑选优质建站一级代理提升网站排名?
c# Task.ConfigureAwait(true) 在什么场景下是必须的
如何快速完成中国万网建站详细流程?
Swift中switch语句区间和元组模式匹配
攀枝花网站建设,攀枝花营业执照网上怎么年审?
高防服务器租用如何选择配置与防御等级?
定制建站流程步骤详解:一站式方案设计与开发指南
青浦网站制作公司有哪些,苹果官网发货地是哪里?
建站之星后台管理:高效配置与模板优化提升用户体验
如何确保西部建站助手FTP传输的安全性?
南平网站制作公司,2025年南平市事业单位报名时间?
怎么将XML数据可视化 D3.js加载XML
想学网站制作怎么学,建立一个网站要花费多少?
定制建站是什么?如何实现个性化需求?
*请认真填写需求信息,我们会在24小时内与您取得联系。