一、分页

1、MyBatisPlusConfig中配置分页插件

  1. /**
  2. * 分页插件
  3. */
  4. @Bean
  5. public PaginationInterceptor paginationInterceptor() {
  6. return new PaginationInterceptor();
  7. }

2、分页Controller方法

TeacherAdminController中添加分页方法

  1. @ApiOperation(value = "分页讲师列表")
  2. @GetMapping("{page}/{limit}")
  3. public R pageList(
  4. @ApiParam(name = "page", value = "当前页码", required = true)
  5. @PathVariable Long page,
  6. @ApiParam(name = "limit", value = "每页记录数", required = true)
  7. @PathVariable Long limit){
  8. Page<Teacher> pageParam = new Page<>(page, limit);
  9. teacherService.page(pageParam, null);
  10. List<Teacher> records = pageParam.getRecords();
  11. long total = pageParam.getTotal();
  12. return R.ok().data("total", total).data("rows", records);
  13. }

3、Swagger中测试

二、条件查询

根据讲师名称name,讲师头衔level、讲师入驻时间gmt_create(时间段)查询

1、创建查询对象

创建com.guli.edu.query包,创建TeacherQuery.java查询对象

  1. package com.guli.edu.query;
  2. @ApiModel(value = "Teacher查询对象", description = "讲师查询对象封装")
  3. @Data
  4. public class TeacherQuery implements Serializable {
  5. private static final long serialVersionUID = 1L;
  6. @ApiModelProperty(value = "教师名称,模糊查询")
  7. private String name;
  8. @ApiModelProperty(value = "头衔 1高级讲师 2首席讲师")
  9. private Integer level;
  10. @ApiModelProperty(value = "查询开始时间", example = "2019-01-01 10:10:10")
  11. private String begin;//注意,这里使用的是String类型,前端传过来的数据无需进行类型转换
  12. @ApiModelProperty(value = "查询结束时间", example = "2019-12-01 10:10:10")
  13. private String end;
  14. }

2、service

接口

  1. package com.guli.edu.service;
  2. public interface TeacherService extends IService<Teacher> {
  3. void pageQuery(Page<Teacher> pageParam, TeacherQuery teacherQuery);
  4. }

实现

  1. package com.guli.edu.service.impl;
  2. @Service
  3. public class TeacherServiceImpl extends ServiceImpl<TeacherMapper, Teacher> implements TeacherService {
  4. @Override
  5. public void pageQuery(Page<Teacher> pageParam, TeacherQuery teacherQuery) {
  6. QueryWrapper<Teacher> queryWrapper = new QueryWrapper<>();
  7. queryWrapper.orderByAsc("sort");
  8. if (teacherQuery == null){
  9. baseMapper.selectPage(pageParam, queryWrapper);
  10. return;
  11. }
  12. String name = teacherQuery.getName();
  13. Integer level = teacherQuery.getLevel();
  14. String begin = teacherQuery.getBegin();
  15. String end = teacherQuery.getEnd();
  16. if (!StringUtils.isEmpty(name)) {
  17. queryWrapper.like("name", name);
  18. }
  19. if (!StringUtils.isEmpty(level) ) {
  20. queryWrapper.eq("level", level);
  21. }
  22. if (!StringUtils.isEmpty(begin)) {
  23. queryWrapper.ge("gmt_create", begin);
  24. }
  25. if (!StringUtils.isEmpty(end)) {
  26. queryWrapper.le("gmt_create", end);
  27. }
  28. baseMapper.selectPage(pageParam, queryWrapper);
  29. }
  30. }

3、controller

TeacherAdminController中修改 pageList方法:
增加参数TeacherQuery teacherQuery,非必选

  1. @ApiOperation(value = "分页讲师列表")
  2. @GetMapping("{page}/{limit}")
  3. public R pageQuery(
  4. @ApiParam(name = "page", value = "当前页码", required = true)
  5. @PathVariable Long page,
  6. @ApiParam(name = "limit", value = "每页记录数", required = true)
  7. @PathVariable Long limit,
  8. @ApiParam(name = "teacherQuery", value = "查询对象", required = false)
  9. TeacherQuery teacherQuery){
  10. Page<Teacher> pageParam = new Page<>(page, limit);
  11. teacherService.pageQuery(pageParam, teacherQuery);
  12. List<Teacher> records = pageParam.getRecords();
  13. long total = pageParam.getTotal();
  14. return R.ok().data("total", total).data("rows", records);
  15. }

4、Swagger中测试