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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: 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进行增删改查的操作。



相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1天前
|
缓存 Java 数据库
springboot数据库及缓存常用依赖及配置
springboot数据库及缓存常用依赖及配置
29 9
|
1天前
|
JavaScript Java 测试技术
基于SpringBoot+Vue的中医学习服务管理系统的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue的中医学习服务管理系统的详细设计和实现(源码+lw+部署文档+讲解等)
16 5
|
2天前
|
Java 关系型数据库 MySQL
Mybatis入门之在基于Springboot的框架下拿到MySQL中数据
Mybatis入门之在基于Springboot的框架下拿到MySQL中数据
12 4
|
2天前
|
SQL Java 数据库连接
2万字实操案例之在Springboot框架下基于注解用Mybatis开发实现基础操作MySQL之预编译SQL主键返回增删改查
2万字实操案例之在Springboot框架下基于注解用Mybatis开发实现基础操作MySQL之预编译SQL主键返回增删改查
11 2
|
20小时前
|
SQL 关系型数据库 MySQL
经验大分享:MySQL(三)数据库表的查询操作【重要】
经验大分享:MySQL(三)数据库表的查询操作【重要】
|
2天前
|
关系型数据库 MySQL 数据库
Mysql数据表操作CRUD
Mysql数据表操作CRUD
6 0
|
2天前
|
关系型数据库 MySQL 数据库
Mysql数据库操作CRUD
Mysql数据库操作CRUD
8 0
|
2天前
|
SQL 数据库 数据库管理
逆向学习数据库篇:多表查询技术详解
逆向学习数据库篇:多表查询技术详解
4 0
|
2天前
|
存储 数据库连接 数据库
逆向学习数据库篇:表设计和数据库操作的核心概念与流程
逆向学习数据库篇:表设计和数据库操作的核心概念与流程
4 0
|
2天前
|
NoSQL Java 关系型数据库
非关系型数据库NoSQL数据层解决方案 之 Mongodb 简介 下载安装 springboot整合与读写操作
非关系型数据库NoSQL数据层解决方案 之 Mongodb 简介 下载安装 springboot整合与读写操作
6 0