1. 基本介绍
SpringBoot帮我们简化了对JDBC连接类型的数据库的操作,只需要配置spring-boot-starter-data-jdbc这个starter,然后在application.properties配置jdbc的相关配置和连接池的相关配置等,就可以对数据库进行操作了
2 自动配置分析
自动配置的类
- DataSourceAutoConfiguration : 数据源的自动配置
- 修改数据源相关的配置:spring.datasource开头的配置参数
查看spring-boot-autoconfigure-2.7.5.jar,可以看到绑定了DataSourceProperties配置类
package org.springframework.boot.autoconfigure.jdbc;
......省略部分......
@EnableConfigurationProperties({DataSourceProperties.class})
@Import({DataSourcePoolMetadataProvidersConfiguration.class})
public class DataSourceAutoConfiguration {
......省略部分......
}
查看DataSourceProperties类,是由spring.datasource开头的配置参数进行配置的
......省略部分......
@ConfigurationProperties(
prefix = "spring.datasource"
)
public class DataSourceProperties implements BeanClassLoaderAware, InitializingBean {
......省略部分......
}
- 数据库连接池的配置,是我们自己容器中没有DataSource才自动配置的
- 底层配置好的连接池是:HikariDataSource。如下所示:
package org.springframework.boot.autoconfigure.jdbc;
......省略部分......
@Configuration(
proxyBeanMethods = false
)
@Conditional({PooledDataSourceCondition.class})
@ConditionalOnMissingBean({DataSource.class, XADataSource.class})
@Import({DataSourceConfiguration.Hikari.class, DataSourceConfiguration.Tomcat.class, DataSourceConfiguration.Dbcp2.class, DataSourceConfiguration.OracleUcp.class, DataSourceConfiguration.Generic.class, DataSourceJmxConfiguration.class})
protected static class PooledDataSourceConfiguration {
protected PooledDataSourceConfiguration() {
}
}
......省略部分......
- DataSourceTransactionManagerAutoConfiguration: 事务管理器的自动配置
- JdbcTemplateAutoConfiguration: JdbcTemplate的自动配置,可以来对数据库进行crud
- 可以修改spring.jdbc开头的参数,来修改JdbcTemplate
- IOC容器中,添加了JDBCTemplate模板
可以看到绑定了JdbcProperties配置类
package org.springframework.boot.autoconfigure.jdbc;
......省略部分......
@AutoConfiguration(
after = {DataSourceAutoConfiguration.class}
)
@ConditionalOnClass({DataSource.class, JdbcTemplate.class})
@ConditionalOnSingleCandidate(DataSource.class)
@EnableConfigurationProperties({JdbcProperties.class})
@Import({DatabaseInitializationDependencyConfigurer.class, JdbcTemplateConfiguration.class, NamedParameterJdbcTemplateConfiguration.class})
public class JdbcTemplateAutoConfiguration {
public JdbcTemplateAutoConfiguration() {
}
}
查看JdbcProperties类,是由spring.jdbc开头的配置参数进行配置的
......省略部分......
@ConfigurationProperties(
prefix = "spring.jdbc"
)
public class JdbcProperties {
......省略部分......
}
而且IOC容器中,也添加了JDBCTemplate组件,如下所示:
package org.springframework.boot.autoconfigure.jdbc;
......省略部分......
@Configuration(
proxyBeanMethods = false
)
@ConditionalOnMissingBean({JdbcOperations.class})
class JdbcTemplateConfiguration {
JdbcTemplateConfiguration() {
}
@Bean
@Primary
JdbcTemplate jdbcTemplate(DataSource dataSource, JdbcProperties properties) {
......省略部分......
}
......省略部分......
}
- JndiDataSourceAutoConfiguration: jndi的自动配置(tomcat会用到)
- XADataSourceAutoConfiguration: 基于XA二阶段提交协议的分布式事务相关的自动配置
3. 实战操作
3.1 pom.xml添加依赖
添加spring-boot-starter-data-jdbc依赖。会自动导入Spring JDBC连接的依赖、HikariCP连接池依赖、Spring的transacation事务依赖
但是并没有导入具体的JDBC驱动依赖,需要我们自己手动添加。默认使用当前最新的版本号,可以通过properties方式或dependency方式指定版本号
<properties>
<mysql.version>8.0.31</mysql.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jdbc</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
</dependencies>
3.2 application.properties配置
配置datasource和jdbc template的参数
# 配置datasource
spring.datasource.url=jdbc:mysql://192.168.28.12:3306/mysql
spring.datasource.username=root
spring.datasource.password=Root_123
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.type=com.zaxxer.hikari.HikariDataSource
# 配置jdbc template
spring.jdbc.template.query-timeout=3
3.3 读取数据测试
新建测试类,如下所示:
package com.hh.springboottest;
import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;
@Slf4j
@SpringBootTest
public class MyApplicationTest {
@Autowired
JdbcTemplate jdbcTemplate;
@Test
public void queryDataTest() {
Long userCount = jdbcTemplate.queryForObject("select count(*) from user", Long.class);
log.info("用户数量为{}", userCount);
}
}
运行程序,结果如下:
......省略部分......
2022-11-18 22:02:46.151 INFO 11216 --- [ main] com.hh.springboottest.MyApplicationTest : 用户数量为4
2022-11-18 22:02:46.172 INFO 11216 --- [ionShutdownHook] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Shutdown initiated...
2022-11-18 22:02:46.183 INFO 11216 --- [ionShutdownHook] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Shutdown completed.