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