spring下mybatis配置多数据源

Spring-Mybatis多数据源配置

使用的spring的数据源代理,org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource.AbstractRoutingDataSource
具体实现代码如下
/**
 * spring中的动态数据源切换
 * @author zhuowen_pan
 */
public class ThreadLocalRoutingDataSource extends AbstractRoutingDataSource {
    @Override
    protected Object determineCurrentLookupKey() {
        return DataSourceContextHolder.getDBHolder();
    }
}
public class DataSourceContextHolder {

    public static final String CURRENT_KEY_DB = "db1";

    public static final String STORE_KEY_DB = "db2";

    public static final String ARCHIVE_KEY_DB = "db3";

    private static final ThreadLocal<String> DB_HOLDER = new ThreadLocal<>();

    public static void setDBHolder(String dbHolder) {
        DB_HOLDER.set(dbHolder);
    }

    static String getDBHolder() {
        return DB_HOLDER.get();
    }

    public static void cleanDBHolder() {
        DB_HOLDER.remove();
    }

    public static void resetDBHolder() {
        DB_HOLDER.remove();
        DB_HOLDER.set(CURRENT_KEY_DB);
    }

}
<bean id="dyDataSource" class="cn.com.jit.cloud.km.common.dal.datasource.ThreadLocalRoutingDataSource"
          primary="true">
        <property name="targetDataSources">
            <map key-type="java.lang.String">
                <entry value-ref="dataSource00" key="db1"/>
                <entry value-ref="dataSource01" key="db2"/>
                <entry value-ref="dataSource02" key="db3"/>
            </map>
        </property>
        <property name="defaultTargetDataSource" ref="dataSource00"/>
    </bean>

dataSource00,dataSource01,dataSource02对应三个数据源,在代码中用根据key来手动切换数据源

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值