同一个SSM项目配置多个数据库

有时候项目可能会连接到不同的数据库上获取数据,那么怎么才能自由切换,让代码查询想要的数据库呢,步骤如下

1,配置数据库连接信息

##第一个数据库信息
DB_MSSQL_URL_1=jdbc:mysql://127.0.0.1:3358/user_1?allowMultiQueries=true
DB_MSSQL_DRIVER_1=com.mysql.jdbc.Driver
DB_MSSQL_USER_1=root
DB_MSSQL_PW_1=456
 
##第二个数据库信息
DB_MSSQL_URL_2=jdbc:mysql://127.0.0.1:3358/user_2?allowMultiQueries=true
DB_MSSQL_DRIVER_2=com.mysql.jdbc.Driver
DB_MSSQL_USER_2=root
DB_MSSQL_PW_2=123

2,创建数据库的bean

<!--第一数据库的信息-->
<bean id="dataSource1" destroy-method="close" class="org.apache.commons.dbcp.BasicDataSource">
	<property name="driverClassName">
		<value>${DB_MSSQL_DRIVER_1}</value>
	</property>
	<property name="url">
		<value>${DB_MSSQL_CMS_URL_1}</value>
	</property>
	<property name="username">
		<value>${DB_MSSQL_USER_1}</value>
	</property>
	<property name="password">
		<value>${DB_MSSQL_PW_1}</value>
	</property>
</bean>
	
<!--第二数据库的信息-->
<bean id="dataSource2" destroy-method="close" class="org.apache.commons.dbcp.BasicDataSource">
	<property name="driverClassName">
		<value>${DB_MSSQL_DRIVER_2}</value>
	</property>
	<property name="url">
		<value>${DB_MSSQL_CMS_URL_2}</value>
	</property>
	<property name="username">
		<value>${DB_MSSQL_USER_2}</value>
	</property>
	<property name="password">
		<value>${DB_MSSQL_PW_2}</value>
	</property>
</bean>

3,配置数据库连接池 

<!-- 编写spring 配置文件的配置多数源映射关系 -->  
<bean class="com.lgg.utils.DynamicDataSource" id="dynamicDataSource">  
    <property name="targetDataSources">  
        <map key-type="java.lang.String">  
            <entry value-ref="dataSource1" key="dataSource1"></entry>  
            <entry value-ref="dataSource2" key="dataSource2"></entry>  
        </map>  
    </property>  
    <property name="defaultTargetDataSource" ref="dataSource1"></property>  
</bean>  
	
<!-- 事务管理器 -->
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
	<!-- 配置为dynamicDataSource -->
	<property name="dataSource" ref="dynamicDataSource"/>
</bean>
<tx:annotation-driven transaction-manager="txManager"/>
<!--自动加载所有的mapper.xml文件,不再需要单独配置  -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <!-- 配置为dynamicDataSource -->
    <property name="dataSource" ref="dynamicDataSource"/>
    <property name="configLocation" value="classpath:spring/sqlMapConfig.xml"/>
    <property name="mapperLocations">
        <value>classpath:mybatis/*.xml</value>
    </property>
</bean>

4,创建类指定用哪个数据库

public class DBContextHolder {
    private static final ThreadLocal<String> contextHolder = new ThreadLocal<String>();
    public static void setDbType(String dbType) {
        contextHolder.set(dbType);
    }
    public static String getDbType() {
        return ((String) contextHolder.get());
    }
    public static void clearDbType() {
        contextHolder.remove();
    }
}

5,自定义动态数据源

public class DynamicDataSource extends AbstractRoutingDataSource {
    @Override
    protected Object determineCurrentLookupKey() {
        return DBContextHolder.getDbType();
    }
}

6,在java代码动态确定调用哪个数据库

public void getUserById(Integer id) {
    User user ;
    if(id == 1){
	 //调用数据库1
        DBContextHolder.setDbType("dataSource1");
        user = userDao.getUserById(1);
    }else{
	 //调用数据库2
        DBContextHolder.setDbType("dataSource2");
        user = userDao.getUserById(2);
    }
    return user;
}

本人做笔记使用,参考:https://blog.csdn.net/u011900448/article/details/79933149

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值