标题1、SQL
1、数据源的自动配置-HikariDataSource
1、导入jdbc场景
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP</artifactId>
<version>4.0.3</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.3.9</version>
<scope>compile</scope>
</dependency>
数据库驱动?
为什么官方不导入驱动?
答:官方不知道我们需要操作什么数据库
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
因为springboot有版本仲裁,所以不需要写版本号,可以进parent内查看版本号以对应自己的数据库版本
如果想要修改版本,根据maven的就近依赖原则可以自行写版本号
2、分析自动配置
1、 自动配置的类
DataSourceAutoConfiguration:数据源的自动配置
修改数据源相关的配置,只需要修改yml文件中的Spring:datasource下的内容
spring:
datasource:
url: jdbc:mysql://localhost:3306/db_acount
username: root
password: 123456
driver-class-name: com.mysql.cj.jdbc.Driver
数据库连接池的配置,是自己容器中没有DataSource才自动配置的
底层配置好的连接池是HikariDataSource
@Configuration(
proxyBeanMethods = false
)
@Conditional({DataSourceAutoConfiguration.PooledDataSourceCondition.class})
@ConditionalOnMissingBean({DataSource.class, XADataSource.class})
@Import({Hikari.class, Tomcat.class, Dbcp2.class, OracleUcp.class, Generic.class, DataSourceJmxConfiguration.class})
protected static class PooledDataSourceConfiguration {
protected PooledDataSourceConfiguration() {
}
DataSourceTransactionManagerAutoConfiguration:事务管理器的自动配置
JdbcTemplateAutoConfiguration:JdbcTemplate的自动配置,可以来对数据库进行crud
可以修改这个配置项@ConfigurationProperties(prefix = “spring.jdbc”)来修改JdbcTemplate
JndiDataSourceAutoConfiguration:jndi的自动配置
XADataSourceAutoConfiguration:分布式事务相关的配置
3、修改配置项
spring:
datasource:
url: jdbc:mysql://localhost:3306/db_acount
username: root
password: 123456
driver-class-name: com.mysql.cj.jdbc.Driver
4、测试