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

员工分页查询功能开发

1. 需求分析

2. 代码开发

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

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

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

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

        //返回结果
        return new PageResult(total,record);
    }
  1. 设计Mapper层
java 复制代码
    Page<Employee> pageQuery(EmployeePageQueryDTO employeePageQueryDTO);
  1. 使用动态SQL进行查询
xml 复制代码
<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测试:

问题

createTime这种是数组形式传递的

前后端联调:

问题:

操作时间渲染格式问题

4. 代码完善

方式一:

代码:

java 复制代码
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private LocalDateTime createTime;

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

数据返回:

方式二:

代码:

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

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

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

数据返回:

相关推荐
毕设源码-钟学长1 天前
【开题答辩全过程】以 基于Java的慕课点评网站为例,包含答辩的问题和答案
java·开发语言
小北方城市网1 天前
分布式锁实战指南:从选型到落地,避开 90% 的坑
java·数据库·redis·分布式·python·缓存
深圳佛手1 天前
使用java,怎么样高效地读取一个大文件(10g以上)?
java·开发语言
sheji34161 天前
【开题答辩全过程】以 景点移动导游系统的设计与实现为例,包含答辩的问题和答案
java
毕设源码-赖学姐1 天前
【开题答辩全过程】以 高校失物招领信息管理系统的设计与开发为例,包含答辩的问题和答案
java
xiaolyuh1231 天前
【XXL-JOB】 GLUE模式 底层实现原理
java·开发语言·前端·python·xxl-job
ohoy1 天前
RedisTemplate 使用之Zset
java·开发语言·redis
独断万古他化1 天前
【Spring 核心: IoC&DI】从原理到注解使用、注入方式全攻略
java·后端·spring·java-ee
梵得儿SHI1 天前
(第四篇)Spring AI 核心技术攻坚:多轮对话与记忆机制,打造有上下文的 AI
java·人工智能·spring·springai生态·上下文丢失问题·三类记忆·智能客服实战案
希忘auto1 天前
SpringBoot之统一数据返回格式
java·spring