springboot学习-使用JdbcTemplate操作MySQL数据库

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: springboot学习-使用JdbcTemplate操作MySQL数据库

springboot系列文章点击阅读原文直达


上一篇文章中我们使用spring-data-jpa实现了操作MySQL数据库,完成了对数据的增删改查,这一篇我们学习使用JdbcTemplate来实现同样的操作。


JdbcTemplate是Spring框架自带的对JDBC操作的封装,目的是提供统一的模板方法使对数据库的操作更加方便、友好,效率也不错。但是功能还是不够强大,在实际应用中通常和hibernate、mybaties等框架混合使用。


新建一个MySQL数据库,这里数据库名为springboot,建立user_info数据表,作为我们示例操作的表对象。


user_info信息如下:

DROP TABLE IF EXISTS `user_info`;
CREATE TABLE `user_info` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `username` varchar(255) DEFAULT NULL,
 `password` varchar(255) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of user_info
-- ----------------------------
INSERT INTO `user_info` VALUES ('1', 'Java之音', '12345');
INSERT INTO `user_info` VALUES ('2', '张无忌', '123');


数据库及表创建成功后,回到我们的工程中



第零步,引入JdbcTemplate的依赖包:


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


第一步,在yml配置文件中配置数据库连接信息:


spring:
 datasource:
   driver-class-name: com.mysql.jdbc.Driver
   url: jdbc:mysql://localhost:3306/springboot?useUnicode=true&characterEncoding=UTF-8&useSSL=false
   username: root
   password: 1011


第二步,创建一个实体类:


package com.javazhiyin;
/**
* Created by 57783 on 2018/7/4.
*/
public class UserInfo {
   private Integer id;
   private String username;
   private String password;
   public Integer getId() {
       return id;
   }
   public void setId(Integer id) {
       this.id = id;
   }
   public String getUsername() {
       return username;
   }
   public void setUsername(String username) {
       this.username = username;
   }
   public String getPassword() {
       return password;
   }
   public void setPassword(String password) {
       this.password = password;
   }
   public UserInfo(){
   }
}


第三步,新建一个Controller,实现对数据库的增删改查操作:


package com.javazhiyin;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.jdbc.core.JdbcTemplate;
import java.util.List;
import java.util.Map;
/**
* Created by 57783 on 2018/7/4.
*/
@RestController
public class UserInfoController {
   @Autowired
   private JdbcTemplate jdbcTemplate;
   /**
    * 查
    * @return
    */
   @GetMapping(value = "/list")
   public List<Map<String, Object>> getUserList(){
       String sql = "select * from user_info";
       List<Map<String, Object>> list = jdbcTemplate.queryForList(sql);
       return list;
   }
   /**
    * 增
    * @param username
    * @param password
    * @return
    */
   @PostMapping(value = "/addUser")
   public String addUser(@RequestParam("username") String username,
                           @RequestParam("password") String password){
       String sql = "insert into user_info (username,password) value (?,?)";
       Object args[] = {username,password};
       int temp = jdbcTemplate.update(sql, args);
       if(temp > 0) {
           return "新增成功";
       }
       return "新增失败";
   }
   /**
    * 改
    * @param id
    * @param username
    * @param password
    * @return
    */
   @PutMapping(value = "updUser/{id}")
   public UserInfo updUser(@PathVariable("id") Integer id,
                       @RequestParam("username") String username,
                       @RequestParam("password") String password){
       String sql = "update user_info set username = ?,password = ? where id = ?";
       Object args[] = {username,password,id};
       int temp = jdbcTemplate.update(sql, args);
       UserInfo user = new UserInfo();
       if(temp > 0) {
           user.setId(id);
           user.setUsername(username);
           user.setPassword(password);
           return user;
       }
       return user;
   }
   /**
    * 删
    * @param id
    */
   @DeleteMapping(value = "delUser/{id}")
   public String delUser(@PathVariable("id") Integer id){
       UserInfo user = new UserInfo();
       user.setId(id);
       String sql = "delete from user_info where id = ?";
       Object args[] = {id};
       int temp = jdbcTemplate.update(sql, args);
       if(temp > 0) {
           return "删除成功";
       }
       return "删除出现错误";
   }
}


测试上述代码,这里我们使用postman测试,非常方便:


查询测试:


image.png


新增测试:



image.png


删除测试:


image.png


我们可以看到可以全部测试通过,完成了springboot使用JdbcTemplate进行增删改查的操作。



相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
14天前
|
前端开发 Java 开发者
Spring生态学习路径与源码深度探讨
【11月更文挑战第13天】Spring框架作为Java企业级开发中的核心框架,其丰富的生态系统和强大的功能吸引了无数开发者的关注。学习Spring生态不仅仅是掌握Spring Framework本身,更需要深入理解其周边组件和工具,以及源码的底层实现逻辑。本文将从Spring生态的学习路径入手,详细探讨如何系统地学习Spring,并深入解析各个重点的底层实现逻辑。
40 9
|
14天前
|
分布式计算 关系型数据库 MySQL
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型 图像处理 光通信 分布式计算 算法语言 信息技术 计算机应用
36 8
|
15天前
|
SQL 前端开发 关系型数据库
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
46 9
|
23天前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。
|
1月前
|
前端开发 Java 数据库
SpringBoot学习
【10月更文挑战第7天】Spring学习
36 9
|
1月前
|
XML Java 数据格式
Spring学习
【10月更文挑战第6天】Spring学习
21 1
|
1月前
|
SQL NoSQL 关系型数据库
数据库学习
【10月更文挑战第8天】
23 1
|
1月前
|
Java 测试技术 开发者
springboot学习四:Spring Boot profile多环境配置、devtools热部署
这篇文章主要介绍了如何在Spring Boot中进行多环境配置以及如何整合DevTools实现热部署,以提高开发效率。
65 2
|
1月前
|
关系型数据库 MySQL Java
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
这篇文章是关于如何使用Django框架配置MySQL数据库,创建模型实例,并自动或手动创建数据库表,以及对这些表进行操作的详细教程。
65 0
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
|
1月前
|
前端开发 Java 程序员
springboot 学习十五:Spring Boot 优雅的集成Swagger2、Knife4j
这篇文章是关于如何在Spring Boot项目中集成Swagger2和Knife4j来生成和美化API接口文档的详细教程。
104 1

热门文章

最新文章