Spring Mybatis多数据源配置

1、在spring的配置文件里面,配置多个数据源,我这里配置两个

<bean id="jobDataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
<bean id="xsDataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
2、很重要,新建一个类继承 AbstractRoutingDataSource

public class MultipleDataSource extends AbstractRoutingDataSource {

    private static ThreadLocal<String> dataSourceKey = new ThreadLocal<String>();

    public static void setDataSourceKey(String dataSource) {
        dataSourceKey.set(dataSource);
    }

    @Override
    protected Object determineCurrentLookupKey() {
        return dataSourceKey.get();
    }
}
对应的spring配置如下:

<bean id="multipleDataSource" class="com.rapoo.job.support.MultipleDataSource">
    <property name="defaultTargetDataSource" ref="jobDataSource"/>
    <property name="targetDataSources">
        <map>
            <entry key="jobDataSource" value-ref="jobDataSource"/>
            <entry key="xsDataSource" value-ref="xsDataSource"/>
        </map>
    </property>
</bean>
3、spring事务配置要改下

<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="multipleDataSource" />
</bean>
4、mybais配置也要改下

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
   <property name="dataSource" ref="multipleDataSource" />
5、完了之后,想要动态切换数据源,需要用AOP方式拦截执行的数据库操作,自动向 ThreadLocal设置数据源的key,见第2步的
setDataSourceKey和determineCurrentLookupKey方法


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值