| New file | 
 |  |  | 
 |  |  | 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; | 
 |  |  |     } | 
 |  |  | } |