基于springboot配置多数据源

1 数据库maven依赖
例如

  <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

2 yml 配置数据源

spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    xxx-data-mysql:
            driverClassName: com.mysql.jdbc.Driver
            dbUrl: jdbc:mysql://ip:3306/databaseName?                                 useUnicode=true&characterEncoding=UTF-   8&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
            username: xxx
            password: xxx
            initialSize: 20
            maxActive: 100
            minIdle: 20
            maxWait: 60000
            poolPreparedStatements: true
            maxPoolPreparedStatementPerConnectionSize: 30
            timeBetweenEvictionRunsMillis: 60000
            minEvictableIdleTimeMillis: 30000
            maxEvictableIdleTimeMillis: 60000
            validationQuery: SELECT 1 FROM DUAL
            testOnBorrow: false
            testOnReturn: false
            testWhileIdle: true
            connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000
            filters: stat,wall

3 创建与yml中数据源映射的数据源类

@Component
@ConfigurationProperties(prefix = "spring.datasource.xxx-data-mysql")  // 与步骤2 中的 
xxx-data-mysql   一一对应
public class DruidLinewellParamMysql {
    private String dbUrl;
    private String username;
    private String password;
    private String driverClassName;
    private int initialSize;
    private int maxActive;
    private int minIdle;
    private int maxWait;
    private boolean poolPreparedStatements;
    private int maxPoolPreparedStatementPerConnectionSize;
    private int timeBetweenEvictionRunsMillis;
    private int minEvictableIdleTimeMillis;
    private int maxEvictableIdleTimeMillis;
    private String validationQuery;
    private boolean testWhileIdle;
    private boolean testOnBorrow;
    private boolean testOnReturn;
    private String filters;
    private String connectionProperties;
    }

4 创建配置类

@Configuration
@MapperScan(basePackages =  {"com.xxl.job.executor.mapper.linewellmysql"},sqlSessionTemplateRef = "sqlSessionTemplatexxxMysql")
public class DruidLinewellConfigMysql {
    private static final Logger LOGGER = LoggerFactory.getLogger(DruidLinewellConfigMysql.class) ;

    @Resource
    private DruidxxxParamMysql druidParam; // 通过此数据源类读取yml文件中数据源信息

    @Bean("dataSourcexxxMysql")
    public DataSource dataSourcexxxMysql () {
        DruidDataSource datasource = new DruidDataSource();
        datasource.setUrl(druidParam.getDbUrl());
        datasource.setUsername(druidParam.getUsername());
        datasource.setPassword(druidParam.getPassword());
        datasource.setDriverClassName(druidParam.getDriverClassName());
        datasource.setInitialSize(druidParam.getInitialSize());
        datasource.setMinIdle(druidParam.getMinIdle());
        datasource.setMaxActive(druidParam.getMaxActive());
        datasource.setMaxWait(druidParam.getMaxWait());
        datasource.setTimeBetweenEvictionRunsMillis(druidParam.getTimeBetweenEvictionRunsMillis());
        datasource.setMinEvictableIdleTimeMillis(druidParam.getMinEvictableIdleTimeMillis());
        datasource.setMaxEvictableIdleTimeMillis(druidParam.getMaxEvictableIdleTimeMillis());
        datasource.setValidationQuery(druidParam.getValidationQuery());
        datasource.setTestWhileIdle(druidParam.isTestWhileIdle());
        datasource.setTestOnBorrow(druidParam.isTestOnBorrow());
        datasource.setTestOnReturn(druidParam.isTestOnReturn());
        datasource.setPoolPreparedStatements(druidParam.isPoolPreparedStatements());
        datasource.setMaxPoolPreparedStatementPerConnectionSize(druidParam.getMaxPoolPreparedStatementPerConnectionSize());
        try {
            datasource.setFilters(druidParam.getFilters());
        } catch (Exception e) {
            LOGGER.error("druid configuration initialization filter", e);
        }
        datasource.setConnectionProperties(druidParam.getConnectionProperties());
        return datasource;
    }

    @Bean
    public SqlSessionFactory sqlSessionFactoryxxxMysql() throws Exception{
        MybatisSqlSessionFactoryBean factory = new MybatisSqlSessionFactoryBean();
        ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
        factory.setDataSource(dataSourcexxxMysql());
        factory.setMapperLocations(resolver.getResources("classpath*:/dataxxxMysqlMapper/*.xml"));
        return factory.getObject();
    }

    @Bean(name="transactionManagerxxxMysql")
    public DataSourceTransactionManager transactionManagerLinewellMysql(){
        return  new DataSourceTransactionManager(dataSourcexxxMysql());
    }

    @Bean(name = "sqlSessionTemplatexxxMysql")
    public SqlSessionTemplate sqlSessionTemplatexxxMysql() throws Exception {
        return new SqlSessionTemplate(sqlSessionFactoryxxxMysql());
    }
}

步骤4 的basePackages放相对应mapper(dao)文件
步骤3,4主要将yml配置的多数据源与对应的mapper(dao)绑定

5 将mapper(dao)文件与创建的xml(sql语句)关联

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值