spring基于通用Dao的多数据源配置详解

有时候在一个项目中会连接多个数据库,需要在spring中配置多个数据源,最近就遇到了这个问题,由于我的项目之前是基于通用Dao的,配置的时候问题不断,这种方式和资源文件冲突;扫描映射文件的话,SqlSessionFactory的bean名字必须是sqlSessionFactory 他读不到sqlSessioNFactory2或者其他名字,最终解决方法如下:

1.在项目中加入如下类MultipleDataSource.java

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
package com.etoak.util;
  
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
  
public class MultipleDataSource extends AbstractRoutingDataSource {
    
  private static final ThreadLocal<String> dataSourceKey = new InheritableThreadLocal<String>(); 
  public static void setDataSourceKey(String dataSource) {
    dataSourceKey.set(dataSource);
  }
  @Override
  protected Object determineCurrentLookupKey() {
    // TODO Auto-generated method stub
    return dataSourceKey.get();
  }
  
}

spring配置文件如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
  
  <context:component-scan base-package="com"/>
    
  <mvc:annotation-driven/>
    
  
  <context:property-placeholder location="classpath:db.properties"/>
  <bean id="ds1" class="org.springframework.jdbc.datasource.DriverManagerDataSource"
    p:driverClassName="${mysql.driver}"
    p:url="${mysql.url}"
    p:username="${mysql.username}"
    p:password="${mysql.password}"/>
  <bean id="ds2" class="org.springframework.jdbc.datasource.DriverManagerDataSource"
    p:driverClassName="${mysql2.driver}"
    p:url="${mysql2.url}"
    p:username="${mysql2.username}"
    p:password="${mysql2.password}"/>
    
    
  <bean id="multipleDataSource" class="com.etoak.util.MultipleDataSource">
    <property name="defaultTargetDataSource" ref="ds1"/>
    <property name="targetDataSources">
      <map>
        <entry key="ds1" value-ref="ds1"/>
        <entry key="ds2" value-ref="ds2"/>
      </map>
    </property>
  </bean>
    
  <bean id="sqlSessionFactory1" class="org.mybatis.spring.SqlSessionFactoryBean"
    p:dataSource-ref="multipleDataSource"
    p:mapperLocations="classpath:com/etoak/dao/*-mapper.xml"/>
    
  <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <property name="basePackage" value="com.etoak.dao"/>
        <property name="markerInterface" value="com.etoak.dao.BaseDao" />
  </bean>  
    
</beans>

测试类如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
package com.etoak.test;
  
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
  
import com.etoak.dao.ProductDaoIf;
import com.etoak.util.MultipleDataSource;
  
public class Test {
  
  public static void main(String[] args) {
    ApplicationContext ac = new 
      FileSystemXmlApplicationContext("WebContent/WEB-INF/etoak-servlet.xml");
      
    ProductDaoIf proDao = (ProductDaoIf)ac.getBean(ProductDaoIf.class);
      
    MultipleDataSource.setDataSourceKey("ds1");
    int count1 = proDao.selectProductCount();
    MultipleDataSource.setDataSourceKey("ds2");
    int count2 = proDao.selectProductCount();
    System.out.println(count1);
    System.out.println(count2);
  }
  
}

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

spring基于通用Dao的多数据源配置详解【ds1】的更多相关文章

  1. spring基于通用Dao的多数据源配置

    有时候在一个项目中会连接多个数据库,须要在spring中配置多个数据源,近期就遇到了这个问题,因为我的项目之前是基于通用Dao的,配置的时候问题不断.这样的方式和资源文件冲突:扫描映射文件的话,Sql ...

  2. Spring MVC配置文件的三个常用配置详解

    转自:http://www.cnblogs.com/benwu/articles/5162614.html Spring MVC项目中通常会有二个配置文件,sprng-servlet.xml和appl ...

  3. spring框架中AOP思想与各种配置详解

    Spring中提供两种AOP支持:   1.基于代理的经典AOP   2.Aspectj注解配置AOP    首先我们先了解什么是AOP,AOP(Aspect Oriented Programming ...

  4. Spring之旅第四篇-注解配置详解

    一.引言 最近因为找工作,导致很长时间没有更新,找工作的时候你会明白浪费的时间后面都是要还的,现在的每一点努力,将来也会给你回报的,但行好事,莫问前程!努力总不会有错的. 上一篇Spring的配置博客 ...

  5. 从Spring到SpringBoot构建WEB MVC核心配置详解

    目录 理解Spring WEB MVC架构的演变 认识Spring WEB MVC 传统时代的Spring WEB MVC 新时代Spring WEB MVC SpringBoot简化WEB MVC开 ...

  6. 小慢歌之基于RHEL8/CentOS8的网络IP配置详解

    ➡ 在rhel8(含centos8)上,没有传统的network.service,在/etc/sysconfig/network-scripts/里也看不到任何脚本文件,那么该如何进行网络配置呢. ➡ ...

  7. Http请求中Content-Type讲解以及在Spring MVC注解中produce和consumes配置详解

    原文地址:  https://blog.csdn.net/shinebar/article/details/54408020 引言: 在Http请求中,我们每天都在使用Content-type来指定不 ...

  8. SpringBoot + Spring Security 基本使用及个性化登录配置详解

    Spring Security 基本介绍 这里就不对Spring Security进行过多的介绍了,具体的可以参考官方文档 我就只说下SpringSecurity核心功能: 认证(你是谁) 授权(你能 ...

  9. 基于RHEL8/CentOS8的网络IP配置详解

    ➡ 在rhel8(含centos8)上,没有传统的network.service,在/etc/sysconfig/network-scripts/里也看不到任何脚本文件,那么该如何进行网络配置呢. ➡ ...

随机推荐

  1. Linux下FastDFS分布式存储-总结及部署记录

    一.分布式文件系统介绍分布式文件系统:Distributed file system, DFS,又叫做网络文件系统:Network File System.一种允许文件通过网络在多台主机上分享的文件系 ...

  2. Gitlab环境快速部署(RPM包方式安装)

    之前梳理了一篇Gitlab的安装CI持续集成系统环境---部署Gitlab环境完整记录,但是这是bitnami一键安装的,版本比较老.下面介绍使用rpm包安装Gitlab,下载地址:https://m ...

  3. 百度之星-1002-list应用

    用stl的list即可,注意...代码的简洁性(被debug伤痛)注意合并时可以手动pop,或者用splice进行合并,不能用merge!!!merge合并是自带排序!!! #include<b ...

  4. hdu 1263 水果 结构的排序+sort自定义排序

    水果 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submissi ...

  5. 读《移山之道-VSTS软件开发指南》

    首先,我选择<移山之道>有几个原因.第一,书的名字给我一种新鲜感,而不是像另外两本书那么平常:第二,作者邹欣是老师推荐的,看一看他的书或许能让我发现老师对他推崇备至的原因,而实际上,读完这 ...

  6. oracle alter

    ALTER TABLE (表名) ADD CONSTRAINT (索引名);ALTER TABLE (表名) DROP CONSTRAINT (索引名); ALTER TABLE (表名) ADD ( ...

  7. Maven项目中添加JDBC驱动

    在pom.xml配置文件中添加: <dependency> <groupId>mysql</groupId> <artifactId>mysql-con ...

  8. 什么是Consul

    什么是Consul Consul文档简要整理 什么是Consul? Consul是一个用来实现分布式系统的服务发现与配置的开源工具.他主要由多个组成部分: 服务发现:客户端通过Consul提供服务,类 ...

  9. Flask-论坛开发-5-memcached缓存系统

    对Flask感兴趣的,可以看下这个视频教程:http://study.163.com/course/courseLearn.htm?courseId=1004091002 ### 介绍:哪些情况下适合 ...

  10. JMX configuration for Tomcat

    Window下执行步骤: D:\apache-tomcat-7.0.57\bin\catalina.bat set CATALINA_OPTS=-Dcom.sun.management.jmxremo ...