使用Springboot实现简单的增删改查(仅记录,不喜勿喷)
首先介绍一下SpringBoot基本框架:
Spring Boot框架层次从上至下可分为5层:
分别为View层,Controller层,Service层,Mapper层,Model层
一:View层:视图根据接受到的数据最终展示页面给用户浏览,需要与Controller层结合起来使用
二:Controller层:负责具体的业务模块流程的控制,响应用户的请求,调用Service层的接口来控制业务流程,决定使用何种视图并准备响应数据,并把接收到的参数传给Mapper,调用Mapper的方法接口
三:Service层:主要负责业务模块的逻辑应用设计,同时有一些是关于数据库处理的操作,但是不是直接和底层数据库相关联,而是首先设计接口,再设计实现其中的类,在接口实现方法中需要导入Mapper层,接着在Spring的配置文件中配置其实现的关联,从而在应用中调用Service接口来进行业务处理
四:Mapper层:主要是做数据持久层的工作,同时提供增删改查工作,Mapper层也是首先设计接口,再设计实现其中的类,具体实现在mapper.xml文件中,然后就可以在模块中调用此接口来进行数据业务的处理
五:Model层:创建对象,包括构造器和get、set方法和toString方法
Controller层:沟通前后端,注解为@RestController
Service层:沟通Mapper层和Controller层,注解为@Service
Mapper层:沟通数据库和Service层,注解为@Repository
对应每个实体,比如说user,需要分别的Controller层,Service层,Mapper层,
Mapper层里面包含一个接口和一个实体类impl,接口负责确定数据连接层的方法,
而impl文件就是直接用来连接数据库的一个实体类
具体的web项目:
controller层->service层(serviceimpl实现service接口)->mapper层->mapper.xml文件
解释:
controller层调用了service的具体功能和方法,service层由service对应的接口和实现类组成,serviceimpl实现service的相关接口同时完成相关的业务逻辑处理
service层(serviceimpl)再调用mapper层的接口进行业务逻辑应用的处理。mapper层的接口在对应的xml配置文件中进行配置、实现和关联,故mapper层的任务就是想数据库发送sql语句,完成数据的处理任务
下面开始进行准备工作:
1.新建项目,名称前缀为ProBuildLog
2.新建数据库wemovetest,新建数据表user,并填写部分数据
3.新建application.yml文件,文件代码如下:
server:
port: 8080
spring:
datasource:
driverClassName: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/wemovetest?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
username: root
password: 123456
mybatis-plus:
#mapper映射文件路径
mapper-locations: classpath*:mapper/*Mapper.xml
#配置扫描包别名
type-aliases-package: com.example.wemove.domain
4.新建以下几个包和包中的类,如图:
5编写相关类和接口的代码:
一:controller层
import com.example.wemove.service.ProBuildLogService;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
@RestController
@RequestMapping("/user")
public class ProBuildLogController{
@Resource
private ProBuildLogService userService;
@RequestMapping("/show") //该注解直接返回字符串
public String show(){
return "user";
}
/**
* 查找角色
* @param id
* @return
*/
@GetMapping( "/getUser/{id}")
public ProBuildLog getUser(@PathVariable Long id) {
return userService.selectUserById(id);
}
/**
* 新增角色
*/
@PostMapping
public boolean insertUser(@Validated @RequestBody ProBuildLog role) {
return userService.insertUser(role);
}
/**
* 删除角色
*/
@DeleteMapping("/{roleIds}")
public boolean deleteUser(@PathVariable Long roleIds) {
return userService.deleteUserById(roleIds);
}
/**
* 状态修改
*/
@PutMapping("/changeStatus")
public boolean changeStatus(@RequestBody ProBuildLog role) {
return userService.updateUser(role);
}
}
二:service层接口
package com.example.wemove.service;
import com.example.wemove.domain.ProBuildLog;
public interface ProBuildLogService{
/**
* 根据id查询用户
* @param id
* @return
*/
ProBuildLog selectUserById(Long id);
/**
* 新增保存角色信息
*
* @param role 角色信息
* @return 结果
*/
boolean insertUser(ProBuildLog role);
/**
* 通过角色ID删除角色
*
* @param roleId 角色ID
* @return 结果
*/
boolean deleteUserById(Long roleId);
/**
* 修改保存角色信息
*
* @param role 角色信息
* @return 结果
*/
boolean updateUser(ProBuildLog role);
}
三:service层接口的imp
package com.example.wemove.service.impl;
import com.example.wemove.domain.ProBuildLog;
import com.example.wemove.mapper.ProBuildLogMapper;
import com.example.wemove.service.ProBuildLogService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@Service
public class ProBuildLogServiceImpl implements ProBuildLogService {
/**
* 注入mapper到service层
*/
@Autowired
private ProBuildLogMapper userMapper; //创建了一个mapper类的变量
/**
* 通过角色ID查询角色
*
* @param id 角色ID
* @return 角色对象信息
*/
@Override
public ProBuildLog selectUserById(Long id) {
return userMapper.selectUserById(id);
}
/**
* 新增保存角色信息
*
* @param role 角色信息
* @return 结果
*/
@Override
@Transactional(rollbackFor = Exception.class)
public boolean insertUser(ProBuildLog role) {
// 新增角色信息
return userMapper.insertUser(role)>0;
}
/**
* 修改保存角色信息
*
* @param role 角色信息
* @return 结果
*/
@Override
@Transactional(rollbackFor = Exception.class)
public boolean updateUser(ProBuildLog role) {
// 修改角色信息
return userMapper.updateUser(role)>0;
}
/**
* 通过角色ID删除角色
*
* @param roleId 角色ID
* @return 结果
*/
@Override
@Transactional
public boolean deleteUserById(Long roleId) {
return userMapper.deleteUserById(roleId)>0;
}
}
}
l四:Mapper层接口
package com.example.wemove.mapper;
import com.example.wemove.domain.ProBuildLog;
import org.apache.ibatis.annotations.Mapper;
@Mapper
public interface ProBuildMapper{
/**
* 根据id查询用户
* @param id
* @return 角色列表
*/
ProBuildLog selectUserById(Long id);
/**
* 修改角色信息
*
* @param role 角色信息
* @return 结果
*/
int updateUser(ProBuildLog role);
/**
* 新增角色信息
*
* @param role 角色信息
* @return 结果
*/
int insertUser(ProBuildLog role);
/**
* 通过角色ID删除角色
*
* @param roleId 角色ID
* @return 结果
*/
int deleteUserById(Long roleId);
}
五:Mapper层xml文件
//id是命名,type是类型
//property是domian里面变量的名称,column是数据库里面的名称
//id是命名,parameterType是接口类型
select * from user where id=#{id}
insert into user() value(#{id},#{name},#{age})
update user set name=#{name},age=#{age} where id=#{id}
delete from user where id=#{id}
6.启动项目即可:
流程解析:
首先是Controller层,该层自动注入了Service层的接口,并且通过该接口的调用了Service层impl的方法,而impl层自动注入了Mapper层的接口,并且通过该接口调用了Mapper层xml的方法,xml文件中的方法通过对应的MySQL语句进行对数据库的操作,从而完成数据处理任务
如图:(图片转载)
7.项目测试:
项目成功启动后,打开ApiFox或PostMan开始进行数据的测试。
一:查询角色:
创建查询角色接口,接口类型为GET,接口路径为http://localhost:8080+/数据表名称+/注解
eg:http://localhost:8080/user/getUser/1
如图:
二:修改角色:
创建修改角色接口,接口类型为PUT,接口路径为http://localhost:8080+/数据表名称+/注解
eg:http://localhost:8080/user/changeStatus
修改前:
_____________________________________________________________________________
_____________________________________________________________________________
修改后:
三:删除角色:
创建删除角色接口,接口类型为DELETE,接口路径为http://localhost:8080+/数据表名称+/注解
eg:http://localhost:8080/use/1
删除后如图:
四:新增角色:
创建新增角色接口,接口类型为POST,接口路径为http://localhost:8080+/数据表名称
eg:http://localhost:8080/user
_____________________________________________________________________________
新增后:
至此,我们已经完成了增删改查的相关工作
感谢浏览,欢迎指教和交流