想要学到更多后端知识,欢迎关注【一心同学】
❤️❤️❤️感谢各位大可爱小可爱!❤️❤️❤️
整合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地位:
HikariDataSource 号称 Java WEB 当前速度最快的数据源,相比于传统的 C3P0 、DBCP、Tomcat jdbc 等连接池更加优秀;
JDBCTemplate
============
SpringBoot对数据库的操作在jdbc上面做了更深层次的封装,而JdbcTemplate便是SpringBoot提供的一个操作数据库的便捷工具。我们可以借助JdbcTemplate来执行所有数据库操作,例如插入,更新,删除和从数据库中检索数据,并且有效避免直接使用jdbc带来的繁琐编码。
JdbcTemplate主要提供以下五种类型的方法:
- execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句。
- update、batchUpdate方法:用于执行新增、修改、删除等语句。
- query方法及queryForXXX方法:用于执行查询相关的语句。
- call方法:用于执行数据库存储过程和 《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》无偿开源 威信搜索公众号【编程进阶路】 函数相关的语句。
开始使用:
编写一个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;



