上一篇对springboot有一个简单的介绍以及使用一个简单的例子熟悉了一下springboot写法的简单流程。这一篇介绍springboot使用JdbcTemplate完成对数据库的增删改查。

首先新建一个简单的数据表,通过操作这个数据表来进行演示

DROP TABLE IF EXISTS `items`;
CREATE TABLE `items` (`id` int(11) NOT NULL AUTO_INCREMENT,`title` varchar(255) DEFAULT NULL,`name` varchar(10) DEFAULT NULL,`detail` varchar(255) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;

引入JdbcTemplate的maven依赖及连接类

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><scope>runtime</scope>
</dependency>

在application.properties文件配置mysql的驱动类,数据库地址,数据库账号、密码信息,application.properties新建在src/main/resource文件夹下

spring.datasource.url=jdbc:mysql://127.0.0.1:3306/spring?useSSL=false
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.max-idle=10
spring.datasource.max-wait=10000
spring.datasource.min-idle=5
spring.datasource.initial-size=5server.port=8080
server.session.timeout=10
server.tomcat.uri-encoding=UTF-8

新建一个实体类,属性对应sql字段

package org.amuxia.start;public class Items {private Integer id;private String title;private String name;private String detail;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getTitle() {return title;}public void setTitle(String title) {this.title = title;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getDetail() {return detail;}public void setDetail(String detail) {this.detail = detail;}public Items() {super();// TODO Auto-generated constructor stub}public Items(Integer id, String title, String name, String detail) {super();this.id = id;this.title = title;this.name = name;this.detail = detail;}@Overridepublic String toString() {return "Items [id=" + id + ", title=" + title + ", name=" + name + ", detail=" + detail + "]";}}

新增操作

/*** 新增数据* @param items* @return*/@RequestMapping("/add")public @ResponseBody String  addItems(Items items) {String sql = "insert into items (id,title,name,detail) value (?,?,?,?)";Object args[] = {items.getId(),items.getTitle(),items.getName(),items.getDetail()};  int temp = jdbcTemplate.update(sql, args); if(temp > 0) {return "文章新增成功";}return "新增出现错误";}

我们做一个测试。在postman测试工具中输入http://localhost:8080/items/add

我们可以看到,新增已经成功了,确实很方便,也没有繁琐的配置信息。

其余删除,更新操作与新增代码不变,只是sql的变化,这里不做演示。

全部查询操作

/*** @return* 查询全部信息*/@RequestMapping("/list")public List<Map<String, Object>> itemsList() {String sql = "select * from items";List<Map<String, Object>> list = jdbcTemplate.queryForList(sql);return list;}

我们做一个测试。在postman测试工具中输入http://localhost:8080/items/list

我们看到,包括刚才新增的数据,都已经被查出来了。

这里为了学习一下springboot的JdbcTemplate操作,所有增删改查代码都写在ItemsController类中,也方便演示,这里把代码贴出来,需要的可以运行一下

package org.amuxia.start;import java.util.List;
import java.util.Map;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;@ComponentScan
@RestController
@RequestMapping("/items")
public class ItemsController {@Autowiredprivate JdbcTemplate jdbcTemplate;/*** @return* 查询全部信息*/@RequestMapping("/list")public List<Map<String, Object>> itemsList() {String sql = "select * from items";List<Map<String, Object>> list = jdbcTemplate.queryForList(sql);return list;}/*** @param id* @return* 根据ID查询单条信息*/@RequestMapping("/detail/{id}")public Map<String, Object> detail(@PathVariable int id) {Map<String, Object> map = null;List<Map<String, Object>> list = itemsList();map = list.get(id);return map;}/*** 新增数据* @param items* @return*/@RequestMapping("/add")public @ResponseBody String  addItems(Items items) {String sql = "insert into items (id,title,name,detail) value (?,?,?,?)";Object args[] = {items.getId(),items.getTitle(),items.getName(),items.getDetail()};  int temp = jdbcTemplate.update(sql, args); if(temp > 0) {return "文章新增成功";}return "新增出现错误";}/*** @param items* @return* 删除数据*/@RequestMapping("/del")public @ResponseBody String  delItems(Items items) {String sql = "delete from items where id = ?";Object args[] = {items.getId()};  int temp = jdbcTemplate.update(sql, args); if(temp > 0) {return "文章删除成功";}return "删除出现错误";}/*** @param items* @return* 更新操作*/@RequestMapping("/upd")public @ResponseBody String  updItems(Items items) {String sql = "update items set title = ?,detail = ? where id = ?";Object args[] = {items.getTitle(),items.getDetail(),items.getId()};  int temp = jdbcTemplate.update(sql, args); if(temp > 0) {return "文章修改成功";}return "修改出现错误";}
}

这里解释一个注解

@ComponentScan:

        @ComponentScan告诉Spring 哪个注解标识的类会被spring自动扫描并且装入bean容器。如果你有个类用@Controller注解标识了,那么,如果不加上@ComponentScan自动扫描该controller,那么该Controller就不会被spring扫描到,更不会装入spring容器中,Controller就不会起作用。

启动类代码

package org.amuxia.start;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.web.bind.annotation.RestController;@RestController
@EnableAutoConfiguration
public class App
{public static void main( String[] args ){System.out.println( "start....." );SpringApplication.run(ItemsController.class, args);}
}

安利一个,关注后端技术精选,号内回复“学习资料”,领取100套小程序源码+小程序开发视频和Java经典书籍电子版!

springboot使用JdbcTemplate完成对数据库的增删改查相关推荐

  1. Springboot使用JPA框架对数据库实现增删改查(附详细代码)

    前言 1.本文将详细阐述如何使用JPA框架对数据库实现增删改查操作,业务中比较常见的应用场景几乎在这里都能看到,并且有详尽的代码可供直观演示,其中遇到的坑也进行了实时标注. 2.JPA的环境配置在前面 ...

  2. 欢迎来到Jsp编程课时十二——今天实现的目标是。@1将数据库的数据发送到浏览器。@2利用浏览器实现对数据库的增删改查操作。@3理解MVC三层架构的定义。

    完成项目会有以下的效果. JSP第二十课:Mvc+Mysql+Servlect+Jsp实现在浏览器上对数据库的增删改查. MVC全名是Model View Controller, 是 @@1模型(mo ...

  3. php修改数据库字段内容,php对数据库的增删改查操作

    在我看来数据库是个既复杂又高深莫测的东西,但百分之八十左右的程序员都不需要去精通他,对于我们前端开发来说,只要会数据库的增删改查语句就差不多了.首先我们来说说sql的增删改查语句. 一.增删改查 插入 ...

  4. shell编程系列22--shell操作数据库实战之shell脚本与MySQL数据库交互(增删改查)

    shell编程系列22--shell操作数据库实战之shell脚本与MySQL数据库交互(增删改查)Shell脚本与MySQL数据库交互(增删改查)# 环境准备:安装mariadb 数据库 [root ...

  5. MySQL数据库学习笔记(十二)----开源工具DbUtils的使用(数据库的增删改查)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  6. 通过Loadruner对mysql数据库进行增删改查

    通过Loadruner对mysql数据库进行增删改查 操作mysql数据库,是在实现mysql数据源配置的基础上操作,可先阅读:loadrunner参数化使用mysql数据源失败解决方法 写之前先理一 ...

  7. Django实现对数据库数据增删改查(二)

    目录 1.基本框架 1.1.路由分发 1.2.视图函数-逻辑处理 1.3.模板 2.查询功能 2.1.视图函数 2.2.模板函数 3.添加功能 3.1.路由分发 3.2视图函数 3.3.模板 4.编辑 ...

  8. 利用koa实现mongodb数据库的增删改查

    概述 使用koa免不了要操纵数据库,现阶段流行的数据库是mongoDB,所以我研究了一下koa里面mongoDB数据库的增删改查,记录下来,供以后开发时参考,相信对其他人也有用. 源代码请看:我的gi ...

  9. jdbc增删改查有哪些步骤_用Mybatis如何实现对数据库的增删改查步骤

    使用Mybatiss实现对数据库的增删改查 文件目录 1.导入jar包,这里使用maven <dependencies><!--mybatis依赖--><!-- org. ...

最新文章

  1. linux tree命令源码,[转帖]linux tree命令--显示目录的树形结构
  2. mysql 8.0认证失败_解决mysql8.0因密码认证插件导致的链接不上
  3. Dynamic Performance Tables not accessible,Automatic Statistics...
  4. 甜甜圈和拓扑学也有关系,你想的到吗?
  5. 平均月薪超过1万的北京人是这样上班的|大数据解读(视频)
  6. Linux特殊权限set_uid、set_gid、stick_bit命令和软链接文件、硬连接文件
  7. Postman测试导出导入Excel教程
  8. 车子刹车油管ABS油管被剪了好几刀,我还有救吗?
  9. 【HAT】 Activating More Pixels in Image Super-Resolution Transformer
  10. 手机安全卫士------查询号码归属地
  11. 工业网络心脏—WiFi 6工业路由器方案IPQ5018方案介绍与应用分析功能特点
  12. Bmob后端云使用步骤
  13. java中文逗号替换英文逗号
  14. chrome浏览器 在线打开预览pdf文件,而不是下载文件。
  15. GridView使用【GridViewHelper】分组统计
  16. java 吸血鬼数字_java编程思想之吸血鬼数字
  17. 【Chrome】图片批量下载扩展zzllrr Imager小乐图客V1.4 (支持正则表达式、自定义JS代码、自定义引擎、多网站取图规则)...
  18. Linux之xinetd安装及实践
  19. 多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么
  20. RTKLIB学习总结(三)RTKGET、RTKCONV、RTKPLOT、RTKPOST、STRSVR的使用

热门文章

  1. 性价比不高却出到8?华为存在感最低的一个系列再发新机
  2. 三星Galaxy Fold全球翻车后 推迟发售时间进一步改进
  3. DXOMark公布最新相机综合评分:华为P30 Pro不再是唯一王者
  4. 程序员打字练习_程序员必须来看的面试圣经!!
  5. 完成一个分析H264码流的工具
  6. ORA-12505,TNS:listener does not currently know of SID given in connect descriptor(不知道的SID)
  7. 【kafka】浅谈Kafka的多线程消费的设计
  8. 【SpringCloud】Spring cloud Alibaba Sentinel 服务降级 (阿里版本Hystrix)
  9. 【Spark】SparkStreaming之windows操作
  10. Linux : rz、sz命令-从本地拷贝文件到服务器