springboot 配置多数据源

/**
 * Mysql 主数据源
 *
 * @author cuixw
 * @date 12/11/2017
 */
/*@Configuration
@MapperScan(basePackages = MasterDataSourceConfig.PACKAGE, sqlSessionFactoryRef = "masterSqlSessionFactory")
public class MasterDataSourceConfig {
    private Logger logger = LoggerFactory.getLogger(MasterDataSourceConfig.class);

    *//**
     * 精确到 master 目录,以便跟其他数据源隔离
     *//*
    static final String PACKAGE = "com.xhs.center.dao.master";
    static final String MAPPER_LOCATION = "classpath:mapper/master/*.xml";


    @Primary
    @Bean(name = "masterDataSource")
    @ConfigurationProperties("spring.datasource.druid.master")
    public DataSource masterDataSource() {
        logger.info("初始化 MySQL 数据源");
        return DruidDataSourceBuilder.create().build();
    }

    @Bean(name = "masterTransactionManager")
    @Primary
    public DataSourceTransactionManager masterTransactionManager() {
        return new DataSourceTransactionManager(masterDataSource());
    }

    @Bean(name = "masterSqlSessionFactory")
    @Primary
    public SqlSessionFactory masterSqlSessionFactory(@Qualifier("masterDataSource") DataSource masterDataSource)
            throws Exception {
        final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
        sessionFactory.setDataSource(masterDataSource);
        sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
                .getResources(MasterDataSourceConfig.MAPPER_LOCATION));
        return sessionFactory.getObject();
    }
}
/**
 * Criminal 数据源
 *
 * @author sqs
 * @date 2018年3月26日
 */
@Configuration
@MapperScan(basePackages = CriminalDataSourceConfig.PACKAGE, sqlSessionFactoryRef = "criminalSqlSessionFactory")
public class CriminalDataSourceConfig {
    private Logger logger = LoggerFactory.getLogger(CriminalDataSourceConfig.class);

    /**
     * 精确到 criminal 目录,以便跟其他数据源隔离
     */
    static final String PACKAGE = "com.xhs.center.dao.a";
    static final String MAPPER_LOCATION = "classpath:mapper/a/*.xml";

    @Bean(name = "criminalDataSource")
    @ConfigurationProperties("spring.datasource.druid.criminal")
    public DataSource criminalDataSource() {
        logger.info("初始化第二个 MySQL 数据源");
        return DruidDataSourceBuilder.create().build();
    }

    @Bean(name = "criminalTransactionManager")
    public DataSourceTransactionManager criminalTransactionManager() {
        return new DataSourceTransactionManager(criminalDataSource());
    }

    @Bean(name = "criminalSqlSessionFactory")
    public SqlSessionFactory criminalSqlSessionFactory(@Qualifier("criminalDataSource") DataSource criminalDataSource)
            throws Exception {
        final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
        sessionFactory.setDataSource(criminalDataSource);
        sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
                .getResources(CriminalDataSourceConfig.MAPPER_LOCATION));
        return sessionFactory.getObject();
    }


}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值