package com.dy.common.singleDataSource;
|
|
import com.alibaba.druid.pool.DruidDataSource;
|
import org.springframework.boot.context.properties.ConfigurationProperties;
|
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Configuration;
|
|
import javax.sql.DataSource;
|
import java.sql.SQLException;
|
|
@Configuration
|
public class DruidDataSourceConfig {
|
|
//编写方法,注入DruidDataSource
|
//还有说明一下为什么我们注入自己的DataSource , 默认的HiKariDatasource失效?
|
//1. 默认的数据源 如配置? @ConditionalOnMissingBean({ DataSource.class, XADataSource.class })
|
// 解读通过@ConditionalOnMissingBean({ DataSource.class}) 判断如果容器有DataSource Bean 就不注入默认的HiKariDatasource
|
@ConfigurationProperties("spring.datasource")
|
@Bean
|
public DataSource dataSource() throws SQLException {
|
//1. 配置了 @ConfigurationProperties("spring.datasource")
|
// 就可以读取到application.yml的配置
|
//2. 我们就不需要调用DruidDataSource 对象的setXxx, 会自动关联
|
|
DruidDataSource druidDataSource = new DruidDataSource();
|
return druidDataSource;
|
}
|
}
|