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

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

前言

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

操作数据库的方式有很多,本文介绍使用SpringBoot结合JdbcTemplate。
大家可以关注一下公众号“Java架构师秘籍” 纯干货绿色天然无污染

新建项目

新建一个项目。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方法
具体使用方法还有很多,请参考文档:
docs.spring.io/spring/docs…

总结注意

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

出现这个错误是因为sql在参数问号的时候多写了引号造成的,这也是我在写demo的时候犯下的错误。
欢迎大家加Q群:230419550 学习交流讨论架构师进阶知识

转载于:https://blog.51cto.com/13792737/2150674

你可能感兴趣的文章
iframe 在ie下面总是弹出新窗口解决方法
查看>>
分享10款漂亮实用的CSS3按钮
查看>>
安装nginx 常见错误及 解决方法
查看>>
Gorun8电子商城
查看>>
在之前链表的基础上改良的链表
查看>>
android编译系统makefile(Android.mk)写法
查看>>
MD5源代码C++
查看>>
Eclipse 添加 Ibator
查看>>
Linux中变量$#,$@,$0,$1,$2,$*,$$,$?的含义
查看>>
Python编程语言
查看>>
十四、转到 linux
查看>>
Got error 241 'Invalid schema
查看>>
ReferenceError: event is not defined
查看>>
男人要内在美,更要外在美
查看>>
为什么要跟别人比?
查看>>
app启动白屏
查看>>
Oracle 提高查询性能(基础)
查看>>
学习知识应该像织网一样去学习——“网状学习法”
查看>>
Hadoop集群完全分布式安装
查看>>
QString,char,string之间赋值
查看>>