当前位置: 首页 > news >正文

Springboot综合练习

        Springboot综合练习,使用三层架构,结合Mybatis操作数据库,接收前端发送的请求,并进行对应的逻辑处理,对数据库增删改查。

        pojo Dept

package com.wzb.pojo;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.time.LocalDateTime;@Data
@NoArgsConstructor
@AllArgsConstructor
public class Dept {private Integer id;private String name;private LocalDateTime createTime;private LocalDateTime updateTime;
}

        统一返回对象Result

package com.wzb.pojo;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;@Data
@NoArgsConstructor
@AllArgsConstructor
public class Result {private Integer code; // 响应码,1是响应成功,2是响应失败private String message; // 响应信息,描述响应结果的字符串private Object data; // 响应返回的数据// 响应成功,但不返回数据的方法public static Result success() {return new Result(1, "success", null);}// 响应成功,并且返回数据的方法public static Result success(Object data) {return new Result(1,"success", data);}// 响应失败的方法public static Result fail(String message) {return new Result(0, message, null);}
}

        Controller层

package com.wzb.controller;import com.wzb.pojo.Dept;
import com.wzb.pojo.Result;
import com.wzb.service.DeptService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;import java.time.LocalDateTime;
import java.util.List;@RestController
@RequestMapping("/depts")
public class DeptController {@Autowiredprivate DeptService deptService;// @RequestMapping(value = "/depts", method = RequestMethod.GET)// 可以使用GetMapping简化@RequestMapping注解,相当于就是将请求的模式(方法)融合到了Mapping中@GetMappingpublic Result getLists() {System.out.println("查询所有部门的信息");List<Dept> deptList = deptService.getDeptList();return Result.success(deptList);}// 可以通过{parameter}在请求路径中请求参数,然后在下面的函数中用@PathVariable注解接收请求的参数// 可以通过@DeleteMapping注解限定请求方式是delete,可以用于简化@RequeatMapping的注解@DeleteMapping("/{id}")public Result deleteDept(@PathVariable Integer id) {System.out.println("根据id删除部门");deptService.deleteDept(id);return Result.success();}// 要新增的部门的信息是前端页面传来的,不需要后端自己定义// 但是需要用@RequestBody注解将前端的json数据填充到实体类中@PostMappingpublic Result insertDept(@RequestBody Dept dept) {System.out.println("新增一个部门");deptService.insertDept(dept);return Result.success(dept);}// 前端请求数据用来更新部门,前端会发送新的部门的名字和要修改的部门的id,需要后端用一个Dept对象接收@PutMappingpublic Result updateDept(@RequestBody Dept dept) {System.out.println("更新一个部门");deptService.updateDept(dept);return Result.success(dept);}// Controller层的优化:以上方法的请求,都有一个共同点:都是以/dept开头————重复了// 在Springboot中为了简化请求路径的定义:可以将公共的请求路径,抽取到类上,在类上加上注解@RequestMapping,// 并且指定请求路径"/depts"
}

        Service接口

package com.wzb.service;import com.wzb.pojo.Dept;import java.util.List;public interface DeptService {public List<Dept> getDeptList();public void deleteDept(Integer id);public void insertDept(Dept dept);public void updateDept(Dept dept);}

        Service实现类

package com.wzb.service;import com.wzb.mapper.DeptMapper;
import com.wzb.pojo.Dept;
import com.wzb.pojo.Result;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import java.time.LocalDateTime;
import java.util.List;@Service
public class DeptServiceImplement implements DeptService{@Autowiredprivate DeptMapper deptMapper;@Overridepublic List<Dept> getDeptList() {return deptMapper.getDeptList();}@Overridepublic void deleteDept(Integer id) {deptMapper.deleteDept(id);}@Overridepublic void insertDept(Dept dept) {// 正常的前端是不可能传递dept的创建时间和dept的修改时间的,// 但是数据库中有这两个字段,所以说需要在后端补齐这些前端缺少的数据// 注:dept的id是自己生成的,所以说前端无需传递,后端也不需要补全dept.setCreateTime(LocalDateTime.now());dept.setUpdateTime(LocalDateTime.now());deptMapper.insertDept(dept);}@Overridepublic void updateDept(Dept dept) {// 修改一个部门,前端会传递id和姓名到后端,后端只需要为其补齐Update_Time的数据dept.setUpdateTime(LocalDateTime.now());deptMapper.updateDept(dept);}
}

        Mapper层(Dao层)

package com.wzb.mapper;import com.wzb.pojo.Dept;
import org.apache.ibatis.annotations.*;import java.util.List;@Mapper
public interface DeptMapper {@Select("select * from dept")public List<Dept> getDeptList();@Delete("delete from dept where id=#{id}")public void deleteDept(Integer id);@Insert("insert into dept (name, create_time, update_time) values(#{name}, #{createTime}, #{updateTime})")public void insertDept(Dept dept);@Update("update dept set name=#{name}, update_time=#{updateTime} where id=#{id}")public void updateDept(Dept dept);
}

 

 

 

 

 


http://www.mrgr.cn/news/37960.html

相关文章:

  • MySQL知识点复习 - 常用的日志类型
  • AI绘画相似风格的作品
  • 【python进阶攻略6】装饰器2
  • c++开发之编译curl(windows版本)
  • matlab r2024a、matlab R2024b保姆级安装教程
  • 在Ubuntu中自动挂载SMB/CIFS共享
  • SpringBoot集成AI:接入大模型框架 LangChain4j 详细教程
  • 基于微信小程序的旅游助手的设计与实现(源码+定制+文档讲解)
  • 每日一题学习笔记
  • 职业技能大赛-单元测试笔记(参数化)分享
  • 828华为云征文|华为云Flexus云服务器X实例之openEuler系统下玩转iSulad容器技术
  • Windows下安装 LLama-Factory 保姆级教程
  • LLM | 迁移 ollama 模型文件到新机器(支持离线运行)
  • Android Button “No speakable text present” 问题解决
  • 鳕鱼检测系统源码分享
  • 周销量超BBA,稳居新势力榜首,理想汽车企稳发展新阶段
  • Android中的页面跳转机制
  • C#中NModbus4中常用的方法
  • Modbus通信协议详解-超级小白必懂
  • 计算机复习9.27