资讯 小学 初中 高中 语言 会计职称 学历提升 法考 计算机考试 医护考试 建工考试 教育百科
栏目分类:
子分类:
返回
空麓网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
空麓网 > 计算机考试 > 软件开发 > 后端开发 > Java

项目一:基于Spring Boot的增删改查(包括测试流程)

Java 更新时间: 发布时间: 计算机考试归档 最新发布

项目一:基于Spring Boot的增删改查(包括测试流程)

使用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: 8080spring:  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: 123456mybatis-plus:  #mapper映射文件路径  mapper-locations: classpath*:mapper    @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{  	    ProBuildLog selectUserById(Long id);  	    boolean insertUser(ProBuildLog role);        boolean deleteUserById(Long roleId);        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;@Servicepublic class ProBuildLogServiceImpl implements ProBuildLogService  {        @Autowired    private ProBuildLogMapper userMapper;          //创建了一个mapper类的变量  	    @Override    public ProBuildLog selectUserById(Long id) {        return userMapper.selectUserById(id);    }  	    @Override    @Transactional(rollbackFor = Exception.class)    public boolean insertUser(ProBuildLog role) {        // 新增角色信息        return userMapper.insertUser(role)>0;    }  	    @Override    @Transactional(rollbackFor = Exception.class)    public boolean updateUser(ProBuildLog role) {        // 修改角色信息       return  userMapper.updateUser(role)>0;    }	        @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;@Mapperpublic interface ProBuildMapper{        ProBuildLog selectUserById(Long id);        int updateUser(ProBuildLog role);        int insertUser(ProBuildLog role);        int deleteUserById(Long roleId);}

五:Mapper层xml文件

                                       //id是命名,type是类型                                                             //property是domian里面变量的名称,column是数据库里面的名称