项目一:基于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: 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文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.wemove.mapper.ProBuildLogMapper">
<resultMap id="ProBuildLogResult" type="ProBuildLog">                                       //id是命名,type是类型
<id property="id" column="id"/>                                                             //property是domian里面变量的名称,column是数据库里面的名称
        <result property="name" column="name"/>
        <result property="age" column="age"/>
    </resultMap>
    <select id="selectUserById" parameterType="long" resultMap="ProBuildLogResult">         //id是命名,parameterType是接口类型
        select * from user where id=#{id}
    </select>
    <insert id="insertUser" parameterType="ProBuildLog">
        insert into user() value(#{id},#{name},#{age})
    </insert>

    <update id="updateUser" parameterType="ProBuildLog">
        update user set name=#{name},age=#{age} where id=#{id}
    </update>

    <delete id="deleteUserById" parameterType="Long">
        delete from user where id=#{id}
    </delete>

</mapper>

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

修改前:

 _____________________________________________________________________________

cd85db8cc68a93100a1c46b6f629930b.png 

_____________________________________________________________________________

修改后:

 

三:删除角色:

创建删除角色接口,接口类型为DELETE,接口路径为http://localhost:8080+/数据表名称+/注解

eg:http://localhost:8080/use/1

删除后如图:

 

四:新增角色:

创建新增角色接口,接口类型为POST,接口路径为http://localhost:8080+/数据表名称

eg:http://localhost:8080/user

_____________________________________________________________________________

新增后:

 80f2f33799ffa93c9d9c8d5c764b3051.png

至此,我们已经完成了增删改查的相关工作

感谢浏览,欢迎指教和交流 

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码
< <上一篇
下一篇>>