• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Java > 详解利用Spring的AbstractRoutingDataSource解决多数据源的问题

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

作者:alaahong 字体:[增加 减小] 来源:互联网 时间:2017-05-28

alaahong 通过本文主要向大家介绍了spring datasource,spring配置datasource,spring abstract,datasource,datasource是什么等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

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

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

研究成果如下:

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> 
</div>

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(); 
  } 
} 
</div>

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(); 
  } 
} 
</div>

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> 
</div>

 5、在DAOImpl中切换数据源

CustomerContextHolder.setCustomerType(CustomerContextHolder.DATA_SOURCE_B);  
</div>

搞定!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • java 自己实现DataSource实现实例
  • 详解利用Spring的AbstractRoutingDataSource解决多数据源的问题
  • java 自己实现DataSource实现实例
  • 详解利用Spring的AbstractRoutingDataSource解决多数据源的问题

相关文章

  • 2017-05-28springMvc注解之@ResponseBody和@RequestBody详解
  • 2017-05-28java中的JSONP使用实例详解
  • 2017-05-28MyBatis拦截器:给参数对象属性赋值的实例
  • 2017-05-28详解hibernate双向多对多关联映射XML与注解版
  • 2017-05-28Java Object类详解_动力节点Java学院整理
  • 2017-05-28详解Spring-Boot集成Spring session并存入redis
  • 2017-05-28java判断ftp目录是否存在的方法
  • 2017-05-28springboot整合quartz实现定时任务示例
  • 2017-05-28java数据结构与算法之简单选择排序详解
  • 2017-05-28详解SpringBoot多跨域请求的支持(JSONP)

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • Java多线程基础 线程的等待与唤醒(wait、notify、notifyAll)
    • Spring 数据库连接池(JDBC)详解
    • Spring boot集成Mybatis的方法教程
    • 详解Spring中Bean的加载的方法
    • java多线程的同步方法实例代码
    • 浅谈JSP与Servlet传值及对比(总结)
    • Java语言简介(动力节点Java学院整理)
    • java判断ftp目录是否存在的方法
    • Java线程中的notifyAll唤醒操作(推荐)
    • 值得Java程序猿阅读的书籍

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有