Spring对数据库的操做在jdbc上面作了更深层次的封装,而JdbcTemplate即是Spring提供的一个操做数据库的便捷工具。咱们能够借助JdbcTemplate来执行全部数据库操做,例如插入,更新,删除和从数据库中检索数据,而且有效避免直接使用jdbc带来的繁琐编码。html
JdbcTemplate主要提供如下五种类型的方法:java
execute方法:能够用于执行任何SQL语句,通常用于执行DDL语句。mysql
update、batchUpdate方法:用于执行新增、修改、删除等语句。git
query方法及queryForXXX方法:用于执行查询相关的语句。web
call方法:用于执行数据库存储过程和函数相关的语句。spring
固然,在大部分状况下,咱们都会直接使用更增强大的持久化框架来访问数据库,好比MyBatis、Hibernate或者Spring Data JPA,咱们这里讲解JdbcTemplate的整合,只是告诉你们有这么一种操做数据库的方式。sql
接下来,咱们就以一个具体的例子来学习如何利用Spring的JdbcTemplate来进行数据库操做。数据库
为方便咱们初始化项目,Spring Boot给咱们提供一个项目模板生成网站。apache
1. 打开浏览器,访问:https://start.spring.io/api
2. 根据页面提示,选择构建工具,开发语言,项目信息等。
3. 点击 Generate the project,生成项目模板,生成以后会将压缩包下载到本地。
4. 使用IDE导入项目,我这里使用Eclipse,经过导入Maven项目的方式导入。
这里使用MySQL数据库,版本是8.0.16,在项目根目录下新建db目录,而后在其中编写一个数据库脚本文件。
在MySQL数据库新建一个springboot数据库,而后在此数据库中执行下面的提供的脚本建立项目的用户表。
脚本文件
SQL脚本内容
springboot.sql
-- ---------------------------- -- Table structure for sys_user -- ---------------------------- DROP TABLE IF EXISTS `sys_user`; CREATE TABLE `sys_user` ( `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '编号', `name` varchar(50) NOT NULL COMMENT '用户名', `nick_name` varchar(150) DEFAULT NULL COMMENT '昵称', `avatar` varchar(150) DEFAULT NULL COMMENT '头像', `password` varchar(100) DEFAULT NULL COMMENT '密码', `salt` varchar(40) DEFAULT NULL COMMENT '加密盐', `email` varchar(100) DEFAULT NULL COMMENT '邮箱', `mobile` varchar(100) DEFAULT NULL COMMENT '手机号', `status` tinyint(4) DEFAULT NULL COMMENT '状态 0:禁用 1:正常', `dept_id` bigint(20) DEFAULT NULL COMMENT '机构ID', `create_by` varchar(50) DEFAULT NULL COMMENT '建立人', `create_time` datetime DEFAULT NULL COMMENT '建立时间', `last_update_by` varchar(50) DEFAULT NULL COMMENT '更新人', `last_update_time` datetime DEFAULT NULL COMMENT '更新时间', `del_flag` tinyint(4) DEFAULT '0' COMMENT '是否删除 -1:已删除 0:正常', PRIMARY KEY (`id`), UNIQUE KEY `name` (`name`) ) ENGINE=InnoDB AUTO_INCREMENT=34 DEFAULT CHARSET=utf8 COMMENT='用户管理';
添加项目须要的相关依赖,这里须要添加上WEB和Swagger和JDBC和MYSQL的依赖,Swagger的添加是为了方便接口测试。
pom.xml
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.5.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.louis.springboot</groupId> <artifactId>demo</artifactId> <version>0.0.1-SNAPSHOT</version> <name>demo</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> </properties> <dependencies> <!-- web --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- swagger --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.9.2</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.9.2</version> </dependency> <!-- jdbc --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> <!-- mysql --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> <!-- 打包时拷贝MyBatis的映射文件 --> <resources> <resource> <directory>src/main/java</directory> <includes> <include>**/sqlmap/*.xml</include> </includes> <filtering>false</filtering> </resource> <resource> <directory>src/main/resources</directory> <includes> <include>**/*.*</include> </includes> <filtering>true</filtering> </resource> </resources> </build> </project>
1.添加数据源配置
将application.properties文件更名为application.yml ,并在其中添加MySQL数据源链接信息。
注意:
这里须要首先建立一个MySQL数据库,并输入本身的用户名和密码。这里的数据库是springboot。
另外,若是你使用的是MySQL 5.x及之前版本,驱动配置driverClassName是com.mysql.jdbc.Driver。
server: port: 8080 spring: datasource: driverClassName: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/springboot?useUnicode=true&zeroDateTimeBehavior=convertToNull&autoReconnect=true&characterEncoding=utf-8 username: root password: 123456
2. 添加swagger 配置
添加一个swagger 配置类,在工程下新建 config 包并添加一个 SwaggerConfig 配置类。
SwaggerConfig.java
package com.louis.springboot.demo.config; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import springfox.documentation.builders.ApiInfoBuilder; import springfox.documentation.builders.PathSelectors; import springfox.documentation.builders.RequestHandlerSelectors; import springfox.documentation.service.ApiInfo; import springfox.documentation.spi.DocumentationType; import springfox.documentation.spring.web.plugins.Docket; import springfox.documentation.swagger2.annotations.EnableSwagger2; @Configuration @EnableSwagger2 public class SwaggerConfig { @Bean public Docket createRestApi(){ return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()) .select() .apis(RequestHandlerSelectors.any()) .paths(PathSelectors.any()).build(); } private ApiInfo apiInfo(){ return new ApiInfoBuilder() .title("SpringBoot API Doc") .description("This is a restful api document of Spring Boot.") .version("1.0") .build(); } }
新建model包并在其中编写model类SysUser。
SysUser.java
package com.louis.springboot.demo.model; import java.util.Date; public class SysUser { private Long id; private String name; private String nickName; private String avatar; private String password; private String salt; private String email; private String mobile; private Byte status; private Long deptId; private String createBy; private Date createTime; private String lastUpdateBy; private Date lastUpdateTime; private Byte delFlag; // 省略setter和getter }
新建dao包并在其中编写dao类SysUserDao,dao包含一些基础的操做方法。
SysUserDao.java
package com.louis.springboot.demo.dao; import java.util.List; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.jdbc.core.BeanPropertyRowMapper; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.stereotype.Repository; import com.louis.springboot.demo.model.SysUser; @Repository public class SysUserDao { @Autowired JdbcTemplate jdbcTemplate; /** * 保存用户 * @param user */ public void save(SysUser user) { String sql = "insert into sys_user(id, name, nick_name, password, email) values(?,?,?,?,?)"; jdbcTemplate.update(sql, user.getId(), user.getName(), user.getNickName(), user.getPassword(), user.getEmail()); } /** * 删除用户 * @param user */ public void delete(String id) { String sql = "delete from sys_user where id=?"; jdbcTemplate.update(sql, id); } /** * 查询所有用户 * @return */ public List<SysUser> findAll() { String sql = "select * from sys_user"; return jdbcTemplate.query(sql, new BeanPropertyRowMapper(SysUser.class)); } }
新建service包并在其中编写服务接口SysUserService。
SysUserService.java
package com.louis.springboot.demo.service; import java.util.List; import com.louis.springboot.demo.model.SysUser; public interface SysUserService { /** * 保存用户 * @param user */ public void save(SysUser user); /** * 删除用户 * @param id */ public void delete(String id); /** * 查询所有用户 * @return */ public List<SysUser> findAll(); }
新建service.impl包并在其中编写服务实现类SysUserServiceImpl并调用DAO实现相关方法。
SysUserServiceImpl.java
package com.louis.springboot.demo.service.impl; import java.util.List; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import com.louis.springboot.demo.dao.SysUserDao; import com.louis.springboot.demo.model.SysUser; import com.louis.springboot.demo.service.SysUserService; @Service public class SysUserServiceImpl implements SysUserService { @Autowired private SysUserDao sysUserDao; @Override public void save(SysUser user) { sysUserDao.save(user); } @Override public void delete(String id) { sysUserDao.delete(id); } @Override public List<SysUser> findAll() { return sysUserDao.findAll(); } }
新建controller包并在其中编写用户控制器SysUserController,并调用相关服务。
SysUserController.java
package com.louis.springboot.demo.controller; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.louis.springboot.demo.model.SysUser; import com.louis.springboot.demo.service.SysUserService; @RestController @RequestMapping("user") public class SysUserController { @Autowired private SysUserService sysUserService; @PostMapping(value="/save") public Object save(@RequestBody SysUser user) { sysUserService.save(user); return 1; } @GetMapping(value="/delete") public Object delete(@RequestParam("id") String id) { sysUserService.delete(id); return 1; } @GetMapping(value="/findAll") public Object findAll() { return sysUserService.findAll(); } }
1. 右键项目 -> Run as -> Maven install,开始执行Maven构建,第一次会下载Maven依赖,可能须要点时间,若是出现以下信息,就说明项目编译打包成功了。
2. 右键文件 DemoApplication.java -> Run as -> Java Application,开始启动应用,当出现以下信息的时候,就说明应用启动成功了,默认启动端口是8080。
3. 打开浏览器,访问:http://localhost:8080/swagger-ui.html,进入swagger接口文档界面。
4. 首先执行如下findAll接口,此时由于没有数据,因此没有返回记录。
接着执行两次save方法,分别保存下面两条记录。
{ "id": 1, "name": "iverson", "nickName": "ai", "password": "123", "email": "iverson@qq.com" }
{ "id": 2, "name": "kobe", "nickName": "kobe", "password": "123", "email": "kobe@qq.com" }
而后再次执行findAll接口,这时咱们能够看到,成功返回了咱们上面插入的两条记录。
接着执行一次delete方法,输入id为1,删除插入的第一条记录。
而后再次执行findAll接口,这时咱们能够看到,咱们插入的第一条记录已经成功被删除。
码云:https://gitee.com/liuge1988/spring-boot-demo.git
做者:朝雨忆轻尘
出处:https://www.cnblogs.com/xifengxiaoma/
版权全部,欢迎转载,转载请注明原文做者及出处。