基于springboot配置多数据源-------分包形式

史上最简单的多数据源(通过分包)

注意目录对应:

/**
 * @author beidouxing
 * @create 2020/05/19 13:30
 */
@Configuration
@MapperScan(basePackages = DataSourceBigcustomerConfig.PACKAGE,sqlSessionTemplateRef = "bigcustomerSqlSessionTemplate")
public class DataSourceBigcustomerConfig {
    /**
     * 对应的bigcustomer 的dao包
     */
    static final String PACKAGE = "org.springblade.mapper.mysql.bigcustomer";
    /**
     * 对应的bigcustomer 的mapper.xml文件
     */
    static final String MAPPER_LOCATION = "classpath:mybatis/mysql/bigcustomer/*.xml";
    @Value("${spring.datasource.bigcustomer.url}")
    private String url;
    @Value("${spring.datasource.bigcustomer.username}")
    private String user;
    @Value("${spring.datasource.bigcustomer.password}")
    private String password;
    @Value("${spring.datasource.bigcustomer.driver-class-name}")
    private String driverClass;

    /**
     * 配置bigcustomer数据源
     */
    @Bean("bigcustomerDataSource")
    public DataSource bigcustomerDataSource(){
        HikariDataSource dataSource = new HikariDataSource();
        dataSource.setJdbcUrl(url);
        dataSource.setUsername(user);
        dataSource.setPassword(password);
        dataSource.setDriverClassName(driverClass);
        return dataSource;
    }

    @Bean("bigcustomerSqlSessionFactory")
    public SqlSessionFactory bigcustomerSqlSessionFactory(@Qualifier("bigcustomerDataSource")DataSource dataSource) throws Exception {
        SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
        sqlSessionFactoryBean.setDataSource(dataSource);
        sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources(DataSourceBigcustomerConfig.MAPPER_LOCATION));
        return sqlSessionFactoryBean.getObject();
    }

    /**
     * 事务管理器
     * @param dataSource
     * @return
     */
    @Bean("bigcustomerTransactionManager")
    public DataSourceTransactionManager bigcustomerTransactionManager(@Qualifier("bigcustomerDataSource")DataSource dataSource){
        return new DataSourceTransactionManager(dataSource);
    }

    @Bean("bigcustomerSqlSessionTemplate")
    public SqlSessionTemplate bigcustomerSqlSessionTemplate(@Qualifier("bigcustomerSqlSessionFactory") SqlSessionFactory sqlSessionFactory){
        return new SqlSessionTemplate(sqlSessionFactory);
    }
}

你说这样写它能不香么
然后就是将对应的mapper文件放到对应的路径下,将对应的mapper.xml放到对应的路径下,就ok了

切记:
	这个可是要在springboot2.0版本以上才行哦!!!!!
	想配几个数据源就照这模样再来几个
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值