博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SpringBoot使用JdbcTemplate
阅读量:7085 次
发布时间:2019-06-28

本文共 8037 字,大约阅读时间需要 26 分钟。

前言

本文是对SpringBoot使用JdbcTemplate操作数据库的一个介绍,,提供一个小的Demo供大家参考。

操作数据库的方式有很多,本文介绍使用SpringBoot结合JdbcTemplate。

新建项目

新建一个项目。pom文件中加入Jdbc依赖,完整pom如下:

4.0.0
com.dalaoyang
springboot_jdbc
0.0.1-SNAPSHOT
jar
springboot_jdbc
springboot_jdbc
org.springframework.boot
spring-boot-starter-parent
1.5.9.RELEASE
UTF-8
UTF-8
1.8
org.springframework.boot
spring-boot-starter-jdbc
org.springframework.boot
spring-boot-devtools
runtime
mysql
mysql-connector-java
runtime
org.springframework.boot
spring-boot-starter-test
test
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-maven-plugin
复制代码

配置文件如下:

##端口号server.port=8888##数据库配置##数据库地址spring.datasource.url=jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=false##数据库用户名spring.datasource.username=root##数据库密码spring.datasource.password=123456##数据库驱动spring.datasource.driver-class-name=com.mysql.jdbc.Driver复制代码

新建一个实体类User,其中需要注意的是,User类实现了RowMapper类,重写了mapRow方法,完整代码如下:

package com.dalaoyang.entity;import org.springframework.jdbc.core.RowMapper;import java.sql.ResultSet;import java.sql.SQLException;/** * @author dalaoyang * @project springboot_learn * @package com.dalaoyang.entity * @email yangyang@dalaoyang.cn * @date 2018/7/25 */public class User implements RowMapper
{ private int id; private String user_name; private String pass_word; public User(int id, String user_name, String pass_word) { this.id = id; this.user_name = user_name; this.pass_word = pass_word; } public User() { } public User(String user_name, String pass_word) { this.user_name = user_name; this.pass_word = pass_word; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUser_name() { return user_name; } public void setUser_name(String user_name) { this.user_name = user_name; } public String getPass_word() { return pass_word; } public void setPass_word(String pass_word) { this.pass_word = pass_word; } @Override public User mapRow(ResultSet resultSet, int i) throws SQLException { User user = new User(); user.setId(resultSet.getInt("id")); user.setUser_name(resultSet.getString("user_name")); user.setPass_word(resultSet.getString("pass_word")); return user; }}复制代码

常用CURD操作大致使用以下三个方法:

1.execute方法,用于直接执行SQL语句
2.update方法,用户新增修改删除操作
3.query方法,用于查询方法

本文和往常一样,用Controller进行测试,注入JdbcTemplate。完整代码如下,下面会对测试方法进行介绍:

package com.dalaoyang.controller;import com.dalaoyang.entity.User;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.jdbc.core.JdbcTemplate;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RestController;import java.util.ArrayList;import java.util.List;import java.util.Map;/** * @author dalaoyang * @project springboot_learn * @package com.dalaoyang.controller * @email yangyang@dalaoyang.cn * @date 2018/7/25 */@RestControllerpublic class UserController {    @Autowired    private JdbcTemplate jdbcTemplate;    //http://localhost:8888/createTable    @GetMapping("createTable")    public String createTable(){        String sql = "CREATE TABLE `user` (\n" +                "  `id` int(11) NOT NULL AUTO_INCREMENT,\n" +                "  `user_name` varchar(255) DEFAULT NULL,\n" +                "  `pass_word` varchar(255) DEFAULT NULL,\n" +                "  PRIMARY KEY (`id`)\n" +                ") ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;\n" +                "\n";        jdbcTemplate.execute(sql);        return "创建User表成功";    }    //http://localhost:8888/saveUserSql    @GetMapping("saveUserSql")    public String saveUserSql(){        String sql = "INSERT INTO USER (USER_NAME,PASS_WORD) VALUES ('dalaoyang','123')";        int rows= jdbcTemplate.update(sql);        return "执行成功,影响"+rows+"行";    }    //http://localhost:8888/saveUser?userName=lisi&passWord=111    @GetMapping("saveUser")    public String saveUser(String userName,String passWord){        int rows= jdbcTemplate.update("INSERT INTO USER (USER_NAME,PASS_WORD) VALUES (?,?)",userName,passWord);        return "执行成功,影响"+rows+"行";    }    //http://localhost:8888/updateUserPassword?id=1&passWord=111    @GetMapping("updateUserPassword")    public String updateUserPassword(int id,String passWord){        int rows= jdbcTemplate.update("UPDATE USER SET PASS_WORD = ? WHERE ID = ?",passWord,id);        return "执行成功,影响"+rows+"行";    }    //http://localhost:8888/deleteUserById?id=1    @GetMapping("deleteUserById")    public String deleteUserById(int id){        int rows= jdbcTemplate.update("DELETE FROM  USER  WHERE ID = ?",id);        return "执行成功,影响"+rows+"行";    }    //http://localhost:8888/batchSaveUserSql    @GetMapping("batchSaveUserSql")    public String batchSaveUserSql(){        String sql =                "INSERT INTO USER (USER_NAME,PASS_WORD) VALUES (?,?)" ;        List
paramList = new ArrayList<>(); for (int i = 0; i < 10; i++) { String[] arr = new String[2]; arr[0] = "zhangsan"+i; arr[1] = "password"+i; paramList.add(arr); } jdbcTemplate.batchUpdate(sql,paramList); return "执行成功"; } //http://localhost:8888/getUserByUserName?userName=zhangsan0 @GetMapping("getUserByUserName") public List getUserByUserName(String userName){ String sql = "SELECT * FROM USER WHERE USER_NAME = ?"; //写法很多种 //下面列举两种写法,都可以实现 //List
list= jdbcTemplate.query(sql,new Object[]{userName}, new BeanPropertyRowMapper(User.class)); List
list= jdbcTemplate.query(sql,new User(),new Object[]{userName}); return list; } //http://localhost:8888/getMapById?id=1 @GetMapping("getMapById") public Map getMapById(Integer id){ String sql = "SELECT * FROM USER WHERE ID = ?"; Map map= jdbcTemplate.queryForMap(sql,id); return map; } //http://localhost:8888/getUserById?id=1 @GetMapping("getUserById") public User getUserById(Integer id){ String sql = "SELECT * FROM USER WHERE ID = ?"; User user= jdbcTemplate.queryForObject(sql,new User(),new Object[]{id}); return user; }}复制代码

测试方法介绍

1.createTable方法

使用execute方法创建User表

2.saveUserSql方法

使用update方法,传入参数sql语句,直接执行插入操作

3.saveUser方法

使用update方法,传入sql语句和对应字段值,进行插入操作

4.updateUserPassword方法

使用update方法,传入sql语句和对应字段值,进行修改操作

5.deleteUserById方法

使用update方法,传入sql语句和对应字段值,进行删除操作

6.batchSaveUserSql方法

使用batchUpdate方法,传入sql和参数集合,进行批量更新

7.getUserByUserName方法

使用query方法,传入sql,实体对象,查询参数,这里就用到了实体类重写的mapRow方法

8.getMapById方法

使用queryForMap方法,传入sql和参数,返回Map

9.getUserById方法

使用queryForObject方法,传入sql,实体对象,查询参数,返回User实体类,这里也用到了实体类重写的mapRow方法

具体使用方法还有很多,请参考文档:

注意

出现下图错误不要担心,如图

出现这个错误是因为sql在参数问号的时候多写了引号造成的,这也是我在写demo的时候犯下的错误。

源码下载 :

个人网站:

关注作者公众号

转载地址:http://jrgml.baihongyu.com/

你可能感兴趣的文章
sqlserver 导入数据出现 无法创建 OLE DB 取值函数。请查看列元数据是否有效
查看>>
block的复习
查看>>
Linux常用命令记录
查看>>
PureMVC和Unity3D的UGUI制作一个简单的员工管理系统实例
查看>>
百度地图坐标转换
查看>>
JavaWeb工作原理
查看>>
MATLAB:图像选取局部区域滤波(roicolor、roipoly、roifill、fspecial、roifilt2函数)...
查看>>
20331关系数据库设计技术
查看>>
wget: unable to resolve host address “mirrors.163.com” 的解决办法
查看>>
JQUERY和AJAX学习
查看>>
git的使用
查看>>
软件平台ThinkSNS+软件系统研发日记
查看>>
samba 使用tips
查看>>
__attribute__
查看>>
[转] 理解 LSTM 网络
查看>>
读取bin文件,并且按结构体赋值打印
查看>>
Java基础积累
查看>>
【Android每日一讲】2012.11.06 Android变脸 - 主题(Theme)实现
查看>>
redis 系列12 哈希对象
查看>>
asp.net core系列 57 IS4 使用混合流(OIDC+OAuth2.0)添加API访问
查看>>