SpringBoot第四篇:整合JDBCTemplate
作者:追梦1819
原文:https://www.cnblogs.com/yanfei1819/p/10868954.html
版权声明:本文为博主原创文章,转载请附上博文链接!
引言
前面几篇文章介绍了 SpringBoot 的一些基本信息,但是还没有跟数据库交互。接下来几章,我们将陆续介绍 SpringBoot 整合各大主流的 ORM 框架。
操作数据库的方式有很多种。本章介绍 JDBCTemplate 操作数据库。
JDBCTemplate 简介
JDBCTemplate 是 Spring 对数据库操作在jdbc上做的深层封装。使用 Spring 的注入功能,可以把DataSource注册到JdbcTemplate 之中。
参照 JdbcTemplate API文档 可以总结出,JDBCTemplate 主要分为四类方法:
- query 方法/ queryForXXX 方法:用于执行查询相关语句;
- update 方法:update 方法用于执行新增、修改、删除等语句;batchUpdate 方法用于执行批处理相关语句;
- execute 方法:可以用于执行任何 SQL 语句,一般用于执行 DDL 语句;
- call 方法:用于执行存储过程、函数相关语句。
## SpringBoot 整合JDBCTemplate
下面以示例演示 JDBCTemplate 在 SpringBoot 中的应用。
首先,是准备工作,初始化表和数据:
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for book
-- ----------------------------
DROP TABLE IF EXISTS `book`;
CREATE TABLE `book` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`book_name` varchar(40) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
`book_price` decimal(10, 2) NOT NULL,
`book_author` varchar(40) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 4 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of book
-- ----------------------------
INSERT INTO `book` VALUES (1, 'java', 45.00, 'shiyanfei');
INSERT INTO `book` VALUES (2, 'PHP', 45.65, 'admin');
SET FOREIGN_KEY_CHECKS = 1;
其次,新建 SpringBoot 工程,创建实体类并引入 maven 依赖:
book 实体类:
package com.yanfei1819.jdbctemplatedemo.entity;
/**
* Created by 追梦1819 on 2019-05-15.
*/
public class Book {
private Long id;
private String bookName;
private Double bookPrice;
private String bookAuthor;
// set/get 省略
}
pom.xml 引入依赖:
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
然后,在 application.properties 中配置数据库信息:
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://192.168.1.88:3306/test?serverTimezone=GMT%2B8
spring.datasource.username=root
spring.datasource.password=pass123
下面,编写测试接口。为了简化代码,此处不对 Java web项目做分层处理,将所有的业务逻辑都放在 controller 层中。
package com.yanfei1819.jdbctemplatedemo.web.controller;
import com.yanfei1819.jdbctemplatedemo.entity.Book;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.web.bind.annotation.*;
import java.util.List;
/**
* Created by 追梦1819 on 2019-05-15.
*/
@RestController
public class BookController {
@Autowired
private JdbcTemplate jdbcTemplate;
// 查询所有的书籍
@GetMapping("/book/queryBooks")
public List<Book> queryBooks(){
String sql = "select * from book ";
return jdbcTemplate.query(sql,new Object[]{},new BeanPropertyRowMapper<>(Book.class));
}
// 根据id查询书籍
@GetMapping("/book/{id}")
public Book queryBookById(@PathVariable Long id){
String sql = "select * from book where id = ?";
return jdbcTemplate.queryForObject(sql,new Object[]{id},new BeanPropertyRowMapper<>(Book.class));
}
// 新增书籍
@PostMapping("/book/save")
public int saveBook(@RequestBody Book book){
String sql = "insert into book(book_name,book_price,book_author) values(?,?,?)";
return jdbcTemplate.update(sql,book.getBookName(),book.getBookPrice(),book.getBookAuthor());
}
// 删除书籍
@GetMapping("/book/delete/{id}")
public int deleteBook(@PathVariable Long id){
String sql = "delete from book where id = ?";
return jdbcTemplate.update(sql,id);
}
}
最后,可用 Postman 或者别的客户端工具进行测试。可以对数据库进行增删改查操作。




总结
市面上有很多 ORM 框架,基本上都是各有优缺点。针对于 JDBCTemplate ,它的优点是更加接近底层的 JDBC,配置少,spring 全家桶自家封装,使用起来简单快捷。但是缺点就是业务代码和 sql 脚本糅合在一起了,不利于 sql 的维护。
个人认为,要使用好 JDBCTemplate ,只需将 JdbcTemplate API文档 仔细研究研究。
源码:我的GitHub
SpringBoot第四篇:整合JDBCTemplate的更多相关文章
- SpringBoot(四)-- 整合Servlet、Filter、Listener
SpringBoot中有两种方式可以添加 Servlet.Filter.Listener. 1.代码注册 通过ServletRegistrationBean. FilterRegistrationBe ...
- springboot学习四:整合mybatis
在application.properties加入配置 ## Mybatis 配置 mybatis.typeAliasesPackage=org.spring.springboot.domain my ...
- springboot第四篇:debug模式开发运用
前提:项目是以maven project结构建立的,现状是无法进行断点调试的.怎么才能在eclipse里进行调试呢? 需要:①将项目打包部署到tomcat ②往项目加入dynamic web modu ...
- SpringBoot第四集:整合JdbcTemplate和JPA(2020最新最易懂)
SpringBoot第四集:整合JdbcTemplate和JPA(2020最新最易懂) 当前环境说明: Windows10_64 Maven3.x JDK1.8 MySQL5.6 SpringTool ...
- springboot 整合jdbcTemplate
springboot 整合jdbcTemplate 〇.搭建springboot环境(包括数据库的依赖) 一.添加依赖 如果导入了jpa的依赖,就不用导入jdbctemplete的依赖了jpa的依赖: ...
- springboot(十四):springboot整合shiro-登录认证和权限管理(转)
springboot(十四):springboot整合shiro-登录认证和权限管理 .embody{ padding:10px 10px 10px; margin:0 -20px; border-b ...
- SpringBoot消息篇Ⅲ --- 整合RabbitMQ
知识储备: 关于消息队列的基本概念我已经在上一篇文章介绍过了(传送门),本篇文章主要讲述的是SpringBoot与RabbitMQ的整合以及简单的使用. 一.安装RabbitMQ 1.在linux上 ...
- SpringBoot分布式篇Ⅷ --- 整合SpringCloud
SpringCloud是一个分布式的整体解决方案.Spring Cloud为开发者提供了在分布式系统(配置管理,服务发现,熔断,路由,微代理,控制总线,一次性token,全局锁,leader选举.分布 ...
- SpringBoot第六篇:整合通用Mapper
作者:追梦1819 原文:https://www.cnblogs.com/yanfei1819/p/10876339.html 版权声明:本文为博主原创文章,转载请附上博文链接! 引言 在以往的项 ...
随机推荐
- 服务器部署Laravel
安装lnmp环境 参考:简书 - Centos 7 下安装LNMP官方最新版 安装redis 参考:简书 - Centos 7下使用yum安装redis 安装nodejs npm nodejs分8.x ...
- C# - VS2019WinFrm桌面应用程序FtpClient实现
前言 本篇主要记录:VS2019 WinFrm桌面应用程序实现简单的FtpClient,包含Ftp文件查看.上传和下载等功能. 准备工作 搭建WinFrm前台界面 添加必要的控件,这里主要应用到Gro ...
- minggw 安装
windows上如果没有安装 visual studio, 也就是俗称的vs, 在安装一些带有c或者c++代码的Python模块的时候, 会报错Unable to find vcvarsall.bat ...
- Winform中使用FastReport的PictureObject时通过代码设置图片源并使Image图片旋转90度
场景 FastReport安装包下载.安装.去除使用限制以及工具箱中添加控件: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- 智能社javascript
http://www.chuanke.com/?mod=student&act=study&courseid=91706
- 多线程学习笔记(一) InvokeRequired 和 delegate
入门示例: 假如有一个label,我们希望像走马灯一样,从1显示到100 private void button1_Click(object sender, EventArgs e) { ; i &l ...
- 在VideoFileClip函数中获取“OSError:[WinError 6]句柄无效”
我正在使用python通过导入moviepy库创建一个程序,但收到以下错误: from moviepy.editor import VideoFileClip white_output = 'vide ...
- 获取APK的appPackage和appActivity
[法二]AndroidSDK 此方法是采用AndroidSDK\build-tools\23.0.2(这个版本号可能不一定,但是一般每个版本号里面都,任意即可)\aapt.exe aapt dump ...
- Python3——根据m3u8下载视频(下)之requests
下半场ING,好吧,本来准备明天写的(拖延真快乐.gif),请然而,,,早上八点多跑公司加班(看书+学习)去,发现大门上挂着一把大锁,我只想说门禁是拿来看的嘛,加啥破锁o(╥﹏╥)o,严重打击了好员工 ...
- 201871010101-陈来弟《面向对象程序设计(Java)》第十二周学习总结
201871010101-陈来弟<面向对象程序设计(Java)>第十二周学习总结 实验十 集合与GUI初步 实验时间 2019-11-14 第一部分 理论部分 1.(1) 用户界面 ...