基于SpringBoot+Redis的前后端分离外卖项目-苍穹外卖(三)

梦里梦外; 2024-04-17 10:08 142阅读 0赞

员工分页查询和账号启用禁用功能

      1. 员工分页查询
      • 1.1 需求分析和设计
        • 1.1.1 产品原型
        • 1.1.2 接口设计
      • 1.2 代码开发
        • 1.2.1 设计DTO类
        • 1.2.2 封装PageResult
        • 1.2.3 Controller层
        • 1.2.4 Service层接口
        • 1.2.5 Service层实现类
        • 1.2.6 Mapper层
      • 1.3 功能测试
      • 1.4 代码完善
      1. 启用禁用员工账号
      • 2.1 需求分析与设计
        • 2.1.1 产品原型
        • 2.1.2 接口设计
      • 2.2 代码开发
        • 2.2.1 Controller层
        • 2.2.2 Service层接口
        • 2.2.3 Service层实现类
        • 2.2.4 Mapper层
      • 2.3 功能测试

1. 员工分页查询

1.1 需求分析和设计

1.1.1 产品原型

查询员工原型:

在这里插入图片描述

业务规则

  • 根据页码展示员工信息
  • 每页展示10条数据
  • 分页查询时可以根据需要,输入员工姓名进行查询
1.1.2 接口设计

在这里插入图片描述
在这里插入图片描述

注意事项:

  • 请求参数类型为Query,不是json格式提交,在路径后直接拼接。/admin/employee/page?name=zhangsan
  • 返回数据中records数组中使用Employee实体类对属性进行封装。

1.2 代码开发

1.2.1 设计DTO类

根据请求参数进行封装,在sky-pojo模块中

  1. package com.sky.dto;
  2. import lombok.Data;
  3. import java.io.Serializable;
  4. @Data
  5. public class EmployeePageQueryDTO implements Serializable {
  6. //员工姓名
  7. private String name;
  8. //页码
  9. private int page;
  10. //每页显示记录数
  11. private int pageSize;
  12. }
1.2.2 封装PageResult

后面所有的分页查询,统一都封装为PageResult对象。

在sky-common模块

  1. package com.sky.result;
  2. import lombok.AllArgsConstructor;
  3. import lombok.Data;
  4. import lombok.NoArgsConstructor;
  5. import java.io.Serializable;
  6. import java.util.List;
  7. /**
  8. * 封装分页查询结果
  9. */
  10. @Data
  11. @AllArgsConstructor
  12. @NoArgsConstructor
  13. public class PageResult implements Serializable {
  14. private long total; //总记录数
  15. private List records; //当前页数据集合
  16. }

员工信息分页查询后端返回的对象类型为: Result

  1. package com.sky.result;
  2. import lombok.Data;
  3. import java.io.Serializable;
  4. /**
  5. * 后端统一返回结果
  6. * @param <T>
  7. */
  8. @Data
  9. public class Result<T> implements Serializable {
  10. private Integer code; //编码:1成功,0和其它数字为失败
  11. private String msg; //错误信息
  12. private T data; //数据
  13. public static <T> Result<T> success() {
  14. Result<T> result = new Result<T>();
  15. result.code = 1;
  16. return result;
  17. }
  18. public static <T> Result<T> success(T object) {
  19. Result<T> result = new Result<T>();
  20. result.data = object;
  21. result.code = 1;
  22. return result;
  23. }
  24. public static <T> Result<T> error(String msg) {
  25. Result result = new Result();
  26. result.msg = msg;
  27. result.code = 0;
  28. return result;
  29. }
  30. }
1.2.3 Controller层

在sky-server模块中,com.sky.controller.admin.EmployeeController中添加分页查询方法。

  1. /**
  2. * 员工分页查询
  3. * @param employeePageQueryDTO
  4. * @return
  5. */
  6. @GetMapping("/page")
  7. @ApiOperation("员工分页查询")
  8. public Result<PageResult> page(EmployeePageQueryDTO employeePageQueryDTO){
  9. log.info("员工分页查询,参数为:{}", employeePageQueryDTO);
  10. PageResult pageResult = employeeService.pageQuery(employeePageQueryDTO);//后续定义
  11. return Result.success(pageResult);
  12. }
1.2.4 Service层接口

在EmployeeService接口中声明pageQuery方法:

  1. /**
  2. * 分页查询
  3. * @param employeePageQueryDTO
  4. * @return
  5. */
  6. PageResult pageQuery(EmployeePageQueryDTO employeePageQueryDTO);
1.2.5 Service层实现类

在EmployeeServiceImpl中实现pageQuery方法:

  1. /**
  2. * 分页查询
  3. *
  4. * @param employeePageQueryDTO
  5. * @return
  6. */
  7. public PageResult pageQuery(EmployeePageQueryDTO employeePageQueryDTO) {
  8. // select * from employee limit 0,10
  9. //开始分页查询
  10. PageHelper.startPage(employeePageQueryDTO.getPage(), employeePageQueryDTO.getPageSize());
  11. Page<Employee> page = employeeMapper.pageQuery(employeePageQueryDTO);//后续定义
  12. long total = page.getTotal();
  13. List<Employee> records = page.getResult();
  14. return new PageResult(total, records);
  15. }

注意:此处使用 mybatis 的分页插件 PageHelper 来简化分页代码的开发。底层基于 mybatis 的拦截器实现。

故在pom.xml文中添加依赖

  1. <dependency>
  2. <groupId>com.github.pagehelper</groupId>
  3. <artifactId>pagehelper-spring-boot-starter</artifactId>
  4. <version>${pagehelper}</version>
  5. </dependency>
1.2.6 Mapper层

在 EmployeeMapper 中声明 pageQuery 方法:

  1. /**
  2. * 分页查询
  3. * @param employeePageQueryDTO
  4. * @return
  5. */
  6. Page<Employee> pageQuery(EmployeePageQueryDTO employeePageQueryDTO);

在 src/main/resources/mapper/EmployeeMapper.xml 中编写SQL:

  1. <select id="pageQuery" resultType="com.sky.entity.Employee">
  2. select * from employee
  3. <where>
  4. <if test="name != null and name != ''">
  5. and name like concat('%',#{name},'%')
  6. </if>
  7. </where>
  8. order by create_time desc
  9. </select>

1.3 功能测试

重启服务:访问http://localhost:8080/doc.html,进入员工分页查询。

点击员工管理

在这里插入图片描述

输入员工姓名为zhangsan

在这里插入图片描述

发现,最后操作时间格式不清晰,再解决一下。

在这里插入图片描述

1.4 代码完善

问题描述:操作时间字段显示有问题。

在这里插入图片描述
解决方式:

1). 方式一

在属性上加上注解,对日期进行格式化

在这里插入图片描述

但这种方式,需要在每个时间属性上都要加上该注解,使用较麻烦,不能全局处理。

2). 方式二(推荐 )

在WebMvcConfiguration中扩展SpringMVC的消息转换器,统一对日期类型进行格式处理

  1. /**
  2. * 扩展Spring MVC框架的消息转化器
  3. * @param converters
  4. */
  5. protected void extendMessageConverters(List<HttpMessageConverter<?>> converters) {
  6. log.info("扩展消息转换器...");
  7. //创建一个消息转换器对象
  8. MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter();
  9. //需要为消息转换器设置一个对象转换器,对象转换器可以将Java对象序列化为json数据
  10. converter.setObjectMapper(new JacksonObjectMapper());
  11. //将自己的消息转化器加入容器中
  12. converters.add(0,converter);
  13. }

添加后,再次测试

在这里插入图片描述

时间格式定义,sky-common模块中

  1. package com.sky.json;
  2. public class JacksonObjectMapper extends ObjectMapper {
  3. //.......
  4. public static final String DEFAULT_DATE_TIME_FORMAT = "yyyy-MM-dd HH:mm";
  5. //.......
  6. }
  7. }

2. 启用禁用员工账号

2.1 需求分析与设计

2.1.1 产品原型

在员工管理列表页面,可以对某个员工账号进行启用或者禁用操作。账号禁用的员工不能登录系统,启用后的员工可以正常登录。如果某个员工账号状态为正常,则按钮显示为 “禁用”,如果员工账号状态为已禁用,则按钮显示为”启用”。

启禁用员工原型:

在这里插入图片描述

业务规则:

  • 可以对状态为“启用” 的员工账号进行“禁用”操作。
  • 可以对状态为“禁用”的员工账号进行“启用”操作。
  • 状态为“禁用”的员工账号不能登录系统。
2.1.2 接口设计

在这里插入图片描述
在这里插入图片描述

1). 路径参数携带状态值。

2). 同时,把id传递过去,明确对哪个用户进行操作。

3). 返回数据code状态是必须,其它是非必须。

2.2 代码开发

2.2.1 Controller层

在sky-server模块中,根据接口设计中的请求参数形式对应的在 EmployeeController 中创建启用禁用员工账号的方法:

  1. /**
  2. * 启用禁用员工账号
  3. * @param status
  4. * @param id
  5. * @return
  6. */
  7. @PostMapping("/status/{status}")
  8. @ApiOperation("启用禁用员工账号")
  9. public Result startOrStop(@PathVariable Integer status,Long id){
  10. log.info("启用禁用员工账号:{},{}",status,id);
  11. employeeService.startOrStop(status,id);//后绪步骤定义
  12. return Result.success();
  13. }
2.2.2 Service层接口

在 EmployeeService 接口中声明启用禁用员工账号的业务方法:

  1. /**
  2. * 启用禁用员工账号
  3. * @param status
  4. * @param id
  5. */
  6. void startOrStop(Integer status, Long id);
2.2.3 Service层实现类

在 EmployeeServiceImpl 中实现启用禁用员工账号的业务方法:

  1. /**
  2. * 启用禁用员工账号
  3. *
  4. * @param status
  5. * @param id
  6. */
  7. public void startOrStop(Integer status, Long id) {
  8. Employee employee = Employee.builder()
  9. .status(status)
  10. .id(id)
  11. .build();
  12. employeeMapper.update(employee);
  13. }
2.2.4 Mapper层

在 EmployeeMapper 接口中声明 update 方法:

  1. /**
  2. * 根据主键动态修改属性
  3. * @param employee
  4. */
  5. void update(Employee employee);

在 EmployeeMapper.xml 中编写SQL:

  1. <update id="update" parameterType="Employee">
  2. update employee
  3. <set>
  4. <if test="name != null">name = #{name},</if>
  5. <if test="username != null">username = #{username},</if>
  6. <if test="password != null">password = #{password},</if>
  7. <if test="phone != null">phone = #{phone},</if>
  8. <if test="sex != null">sex = #{sex},</if>
  9. <if test="idNumber != null">id_Number = #{idNumber},</if>
  10. <if test="updateTime != null">update_Time = #{updateTime},</if>
  11. <if test="updateUser != null">update_User = #{updateUser},</if>
  12. <if test="status != null">status = #{status},</if>
  13. </set>
  14. where id = #{id}
  15. </update>

2.3 功能测试

测试前:

在这里插入图片描述

点击启用:

在这里插入图片描述

后记
????美好的一天,到此结束,下次继续努力!欲知后续,请看下回分解,写作不易,感谢大家的支持!! ???

发表评论

表情:
评论列表 (有 0 条评论,142人围观)

还没有评论,来说两句吧...

相关阅读