全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解利用Spring的AbstractRoutingDataSource解决多数据源的问题

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

原来的项目出现了新需求,局方要求新增某服务器用以提供某代码,涉及到多数据源的问题。

研究成果如下:

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小时内与您取得联系。