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);
}