Mybatis多个数据库连接配置

Mybatis多个数据库连接配置

1 数据库的连接信息

在这里插入图片描述

app.properties配置文件中的两个数据库的连接信息

2 mybatis配置文件读取app.properties中的连接信息

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
	xmlns:context="http://www.springframework.org/schema/context"
	
	xmlns:mvc="http://www.springframework.org/schema/mvc"
	xsi:schemaLocation="http://www.springframework.org/schema/beans    
                        http://www.springframework.org/schema/beans/spring-beans-3.1.xsd    
                        http://www.springframework.org/schema/context    
                        http://www.springframework.org/schema/context/spring-context-3.1.xsd    
                        http://www.springframework.org/schema/mvc    
                        http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"
                        >
	<context:annotation-config />
	<!-- 自动扫描 -->
	<context:component-scan base-package="com.ekp.controller" />
	<!-- 引入配置文件 -->
	<bean id="propertyConfigurer"
		class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
		<property name="location" value="classpath:conf/app.properties" />
	</bean>
	
	<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"  destroy-method="close">
		<!-- 用户名 -->
		<property name="user" value="${jdbc.username}" />
		<!-- 用户密码 -->
		<property name="password" value="${jdbc.password}" />
		<property name="driverClass" value="${jdbc.driverClass}" />
		<property name="jdbcUrl" value="${jdbc.url}" />

		<!--连接池中保留的最大连接数。默认值: 15 -->
		<property name="maxPoolSize" value="20" />
		<!-- 连接池中保留的最小连接数,默认为:3 -->
		<property name="minPoolSize" value="2" />
		<!-- 初始化连接池中的连接数,取值应在minPoolSize与maxPoolSize之间,默认为3 -->
		<property name="initialPoolSize" value="2" />

		<!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。默认值: 0 -->
		<property name="maxIdleTime" value="60" />

		<!-- 当连接池连接耗尽时,客户端调用getConnection()后等待获取新连接的时间,超时后将抛出SQLException,如设为0则无限期等待。单位毫秒。默认: 0 -->
		<property name="checkoutTimeout" value="3000" />

		<!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。默认值: 3 -->
		<property name="acquireIncrement" value="2" />

		<!--定义在从数据库获取新连接失败后重复尝试的次数。默认值: 30 ;小于等于0表示无限次 -->
		<property name="acquireRetryAttempts" value="0" />

		<!--重新尝试的时间间隔,默认为:1000毫秒 -->
		<property name="acquireRetryDelay" value="1000" />

		<!--关闭连接时,是否提交未提交的事务,默认为false,即关闭连接,回滚未提交的事务 -->
		<property name="autoCommitOnClose" value="false" />
		
		<!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试使用。默认值: null -->
		<property name="automaticTestTable" value="Test" /> 

		<!--如果为false,则获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常,但是数据源仍有效保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试获取连接失败后该数据源将申明已断开并永久关闭。默认: false -->
		<property name="breakAfterAcquireFailure" value="false" />

		<!--每60秒检查所有连接池中的空闲连接。默认值: 0,不检查 -->
		<property name="idleConnectionTestPeriod" value="60" />

		<!--c3p0全局的PreparedStatements缓存的大小。如果maxStatements与maxStatementsPerConnection均为0,则缓存不生效,只要有一个不为0,则语句的缓存就能生效。如果默认值: 0 -->
		<property name="maxStatements" value="100" />
		
		<!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。默认值: 0 -->
		<!-- <property name="maxStatementsPerConnection" value="0"> -->
	</bean>


<bean id="dataSource1" class="com.mchange.v2.c3p0.ComboPooledDataSource"  destroy-method="close">
		
		<!-- 用户名 -->
		<property name="user" value="${jdbc.MDM.username}" />
		<!-- 用户密码 -->
		<property name="password" value="${jdbc.MDM.password}" />
		<property name="driverClass" value="${jdbc.MDM.driverClass}" />
		<property name="jdbcUrl" value="${jdbc.MDM.url}" />

		<!--连接池中保留的最大连接数。默认值: 15 -->
		<property name="maxPoolSize" value="20" />
		<!-- 连接池中保留的最小连接数,默认为:3 -->
		<property name="minPoolSize" value="2" />
		<!-- 初始化连接池中的连接数,取值应在minPoolSize与maxPoolSize之间,默认为3 -->
		<property name="initialPoolSize" value="2" />

		<!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。默认值: 0 -->
		<property name="maxIdleTime" value="60" />

		<!-- 当连接池连接耗尽时,客户端调用getConnection()后等待获取新连接的时间,超时后将抛出SQLException,如设为0则无限期等待。单位毫秒。默认: 0 -->
		<property name="checkoutTimeout" value="3000" />

		<!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。默认值: 3 -->
		<property name="acquireIncrement" value="2" />

		<!--定义在从数据库获取新连接失败后重复尝试的次数。默认值: 30 ;小于等于0表示无限次 -->
		<property name="acquireRetryAttempts" value="0" />

		<!--重新尝试的时间间隔,默认为:1000毫秒 -->
		<property name="acquireRetryDelay" value="1000" />

		<!--关闭连接时,是否提交未提交的事务,默认为false,即关闭连接,回滚未提交的事务 -->
		<property name="autoCommitOnClose" value="false" />
		
		<!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试使用。默认值: null -->
		<property name="automaticTestTable" value="Test" /> 

		<!--如果为false,则获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常,但是数据源仍有效保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试获取连接失败后该数据源将申明已断开并永久关闭。默认: false -->
		<property name="breakAfterAcquireFailure" value="false" />

		<!--每60秒检查所有连接池中的空闲连接。默认值: 0,不检查 -->
		<property name="idleConnectionTestPeriod" value="60" />

		<!--c3p0全局的PreparedStatements缓存的大小。如果maxStatements与maxStatementsPerConnection均为0,则缓存不生效,只要有一个不为0,则语句的缓存就能生效。如果默认值: 0 -->
		<property name="maxStatements" value="100" />
		
		<!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。默认值: 0 -->
		<!-- <property name="maxStatementsPerConnection" value="0"> -->
	</bean>

	<bean id="dynamicDataSource" class="com.ekp.persistence.DynamicDataSource">
		<property name="targetDataSources"> 
			<map key-type="java.lang.String">
				<!-- 指定lookupKey和与之对应的数据源 -->
				<entry key="dataSourceFirst" value-ref="dataSource"></entry> 
	  			<entry key="dataSourceSecond" value-ref="dataSource1"></entry> 
	  		</map> 
	   	</property> 
	   	<!-- 这里可以指定默认的数据源 --> 
	 	<property name="defaultTargetDataSource" ref="dataSource" /> 
	 </bean> 



	<!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" ref="dynamicDataSource" />
		<!-- 自动扫描mapping.xml文件 -->
		<property name="mapperLocations" >
			 <list>
                <value>classpath:com/ekp/mapper/*.map.xml</value>
                <value>classpath:com/ekp/mapper/*.xml</value>
            </list>
		</property>
	</bean>

	<!-- DAO接口所在包名,Spring会自动查找其下的类 -->
	<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
		<property name="basePackage" value="com.ekp.dao" />
		<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
	</bean>

	<!-- (事务管理)transaction manager, use JtaTransactionManager for global tx -->
	 <bean id="transactionManager"
		class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource" ref="dynamicDataSource" />
	</bean> 
	
	
	<import resource="app-beans.xml" />
	<import resource="app-job.xml" />
</beans>  

3 创建DynamicDataSource类和DynamicDataSourceHolder类

package com.ekp.persistence;

import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;

public class DynamicDataSource extends AbstractRoutingDataSource{
	 @Override
	 protected Object determineCurrentLookupKey() {
	 // 从自定义的位置获取数据源标识 
		 return DynamicDataSourceHolder.getDataSource();
	   }
}

package com.ekp.persistence;

public class DynamicDataSourceHolder {

	private static final ThreadLocal<String> THREAD_DATA_SOURCE = new ThreadLocal<String>();
	 
	public static String getDataSource() {
		return THREAD_DATA_SOURCE.get();
	 }
	  
	public static void setDataSource(String dataSource) {
	    THREAD_DATA_SOURCE.set(dataSource);
	}
	
	public static void clearDataSource() {
	    THREAD_DATA_SOURCE.remove();
	}
}

4 使用

DynamicDataSourceHolder.setDataSource("dataSourceSecond");
	  //代码逻辑处理
DynamicDataSourceHolder.clearDataSource();

首先有默认的连接,要使用其他数据库连接,set该连接的别名,如果更多的数据库连接可以用自定义注解的方式贴在各个方法上

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis 支持多数据库连接的代码编写方法如下: 1. 配置数据源:在 mybatis配置文件中,为每个数据库配置不同的数据源。 2. 编写 SQL 映射:在 mybatis 的映射文件中,为每个数据库编写对应的 SQL 映射。 3. 设置数据源:在代码中,通过设置不同的数据源,来指定使用哪个数据库进行操作。 例如: ``` // 配置数据源 <!-- database1 --> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/database1"/> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource> <!-- database2 --> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/database2"/> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource> // 编写 SQL 映射 <!-- database1 --> <select id="selectUser" resultType="com.example.User"> SELECT * FROM user WHERE id = #{id} </select> <!-- database2 --> <select id="selectOrder" resultType="com.example.Order"> SELECT * FROM order WHERE id = #{id} </select> // 设置数据源 SqlSession sqlSession1 = sqlSessionFactory.openSession(database1); User user = sqlSession1.selectOne("selectUser", 1); SqlSession sqlSession2 = sqlSessionFactory.openSession(database2); Order order = sqlSession2.selectOne("selectOrder", 1); ``` 希望这对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值