想要学到更多后端知识,欢迎关注【一心同学】
❤️❤️❤️感谢各位大可爱小可爱!❤️❤️❤️
整合JDBC
======
1.创建SpringBoot项目,引入以下模块
Spring Web
JDBC API
MySQL Driver
2.编写yaml配置文件连接数据库;
application.yml:
spring:
datasource:
username: root
password: 123456
#?serverTimezone=UTC解决时区的报错
url: jdbc:mysql://localhost:3306/mybatis?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8
driver-class-name: com.mysql.cj.jdbc.Driver
3.测试数据源
@SpringBootTest
class DemoApplicationTests {
//DI注入数据源
@Autowired
DataSource dataSource;
@Test
void contextLoads() throws SQLException {
//看一下默认数据源
System.out.println(dataSource.getClass());
//获得连接
Connection connection = dataSource.getConnection();
System.out.println(connection);
//关闭连接
connection.close();
}
}
运行:
说明我们数据源就已经配置好了,是不是觉得特别简单,因为SpringBoot已经默认帮我们进行了自动配置。
从运行结果可以得出结论:
我们的数据源是:class com.zaxxer.hikari.HikariDataSource
源码分析
由于数据源的所有自动配置都是在:DataSourceAutoConfiguration文件,我们全局搜索该类去看一下源码。
搜索PooledDataSourceConfiguration方法:
可以看出我们SpringBoot2.6.2使用的默认数据源是:HikariDataSource 数据源,如果是以前的版本Spring Boot 1.5 则默认使用 org.apache.tomcat.jdbc.pool.DataSource 作为数据源;
HikariDataSource地位:
JDBCTemplate
============
SpringBoot对数据库的操作在jdbc上面做了更深层次的封装,而JdbcTemplate便是SpringBoot提供的一个操作数据库的便捷工具。我们可以借助JdbcTemplate来执行所有数据库操作,例如插入,更新,删除和从数据库中检索数据,并且有效避免直接使用jdbc带来的繁琐编码。
开始使用:
编写一个Controller,注入 jdbcTemplate,编写测试方法进行访问测试;
package com.yixin.demo.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.web.bind.annotation.GetMapping;