苍穹外卖Day02总结

Day02主要分为5个部分:新增员工、员工分页查询、启用禁用员工账号、编辑员工和导入分类模块。

新增员工就是普通的Post请求,前端传来json格式数据别忘了用@RequestBody注解;启用禁用员工账号由前端通过路径传来,用@PathVariable注解接收然后包装Employee对象更新数据库;编辑员工分为两个部分,一是根据id查询员工用于回显,二是修改员工与新增员工类似;分类功能模块代码与员工类似,直接导入即可。

我认为比较重点的是员工分页查询,因为这里面用到了PageHelper插件,下面进行一下解析:


1.设计DTO和pageResult

用于封装请求参数和返回,PageResult返回的是总记录数和数据的集合。

@Data
public class EmployeePageQueryDTO implements Serializable {

    //员工姓名
    private String name;

    //页码
    private int page;

    //每页显示记录数
    private int pageSize;

}
@Data
@AllArgsConstructor
@NoArgsConstructor
public class PageResult implements Serializable {

    private long total; //总记录数

    private List records; //当前页数据集合

}

2.PageHelper的使用

首先使用 mybatis 的分页插件 PageHelper 来简化分页代码的开发,底层基于 mybatis 的拦截器实现,后续sql语句会自动加上分页逻辑。方法返回值是一个Page对象,这是 PageHelper 提供的分页结果类,包含了分页的详细信息包括总页数和结果的集合,把它们包装到PageResult结果类进行返回。

	/**
     * 分页查询
     *
     * @param employeePageQueryDTO
     * @return
     */
    public PageResult pageQuery(EmployeePageQueryDTO employeePageQueryDTO) {
        // select * from employee limit 0,10
        //开始分页查询
        PageHelper.startPage(employeePageQueryDTO.getPage(), employeePageQueryDTO.getPageSize());

        Page<Employee> page = employeeMapper.pageQuery(employeePageQueryDTO);//后续定义

        long total = page.getTotal();
        List<Employee> records = page.getResult();

        return new PageResult(total, records);
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值