本文实例讲述了spring多数据源配置实现方法。分享给大家供大家参考,具体如下:
创新互联建站专注为客户提供全方位的互联网综合服务,包含不限于网站设计、网站建设、安溪网络推广、小程序制作、安溪网络营销、安溪企业策划、安溪品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联建站为所有大学生创业者提供安溪建站搭建服务,24小时服务热线:028-86922220,官方网址:www.cdcxhl.com
在网上找到的配置多数据源的方法。
1.扩展org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource
类
实现代码
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource; public class DynamicDataSource extends AbstractRoutingDataSource { @Override protected Object determineCurrentLookupKey() { // TODO Auto-generated method stub return DbContextHolder.getDbType(); } }
2.实现一个线程安全的DbContextHolder类。
public class DbContextHolder { private static final ThreadLocal contextHolder = new ThreadLocal(); public static void setDbType(String dbType) { contextHolder.set(dbType); } /** * 取得dbtype类型 * @return */ public static String getDbType() { String str=(String) contextHolder.get(); if(null==str || "".equals(str)) str="1"; return str; } public static void clearDbType() { contextHolder.remove(); } }
3.修改spring的配置文件。
<!--动态选择数据源--> <bean id="dataSource" class="tecamo.core.utils.DynamicDataSource"> <property name="targetDataSources"> <map key-type="java.lang.String"> <entry key="1" value-ref="ds1"/> <entry key="2" value-ref="ds2"/> </map> </property> <property name="defaultTargetDataSource" ref="ds1"/> </bean> <!-- 数据源定义 --> <bean id="ds1" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${jdbc.driverClassName}"/> <property name="url" value="${jdbc.url}"/> <property name="username" value="${jdbc.username}"/> <property name="password" value="${jdbc.password}"/> </bean> <bean id="ds2" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${jdbcOrcale.driverClassName}"/> <property name="url" value="${jdbcOrcale.url}"/> <property name="username" value="${jdbcOrcale.username}"/> <property name="password" value="${jdbcOrcale.password}"/> </bean>
4.切换数据源方法。
在serverice方法之前调用
DbContextHolder.setDbType("2");
表示使用第二个数据源。
更多关于java相关内容感兴趣的读者可查看本站专题:《Spring框架入门与进阶教程》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。
网站题目:spring多数据源配置实现方法实例分析
文章路径:https://www.cdcxhl.com/article10/pppcdo.html
成都网站建设公司_创新互联,为您提供品牌网站建设、移动网站建设、动态网站、网站制作、电子商务、ChatGPT
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联