注册

苍穹外卖实现员工分页查询

员工分页查询功能开发

1. 需求分析

image-20250727220530038

image-20250727220803745

2. 代码开发

  1. 根据分页查询接口设计对应的DTO

image-20250727220930090

  1. 设计controller层
    @GetMapping("/page")
@ApiOperation(value = "员工分页查询")
public Resultpage(EmployeePageQueryDTO employeePageQueryDTO){
//输出日志
log.info("员工分页查询,查询参数: {}",employeePageQueryDTO);
//调用service层返回分页结果
PageResult pageResult = employeeService.pageQuery(employeePageQueryDTO);
//返回result
return Result.success(pageResult);
}
  1. 设计service层,使用Page Helper进行分页,并返回total和record
 @Override
public PageResult pageQuery(EmployeePageQueryDTO employeePageQueryDTO) {
//开始分页
PageHelper.startPage(employeePageQueryDTO.getPage(), employeePageQueryDTO.getPageSize());

//调用mapper方法返回page对象,泛型为内容的类型,(page实际是一个List)
Page page = employeeMapper.pageQuery(employeePageQueryDTO);

//获取总的数据量
long total = page.getTotal();

//获取所有员工对象
List record = page.getResult();

//返回结果
return new PageResult(total,record);
}
  1. 设计Mapper层
    PagepageQuery(EmployeePageQueryDTO employeePageQueryDTO);
  1. 使用动态SQL进行查询
<select id="pageQuery" resultType="com.sky.entity.Employee">
select * from employee
<where>
<if test="name != null and name != ''">
name like concat('%',#{name},'#')
if>
where>
order by create_time desc
select>

3. 功能测试

Swagger测试:

image-20250727232014532

问题

createTime这种是数组形式传递的

前后端联调:

image-20250727231946460

问题:

操作时间渲染格式问题

4. 代码完善

image-20250727232335111

方式一:

代码:

    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime createTime;

@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime updateTime;

数据返回:

image-20250727232717370

方式二:

代码:

需要在配置类中重写父类的方法,并配置添加消息转换器

 @Override
protected void extendMessageConverters(List> converters)<?> {
log.info("扩展消息转换器");
//创建一个消息转换器
MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter();
//为消息转换器设置一个对象转换器,对象转换器可以将对象数据转换为json数据
converter.setObjectMapper(new JacksonObjectMapper());
//将消息转换器添加到容器中,由于converters内部有很多消息转换器,我们假如的默认排在最后一位
//所以将顺序设置为最靠前
converters.add(0,converter);
}

其中JacksonObjectMapper为自己实现的实体类,写法较为固定

数据返回:

image-20250727234752486


作者:用户4007842211260
来源:juejin.cn/post/7531791862521151528

0 个评论

要回复文章请先登录注册