MyBatis实现分页查询-苍穹外卖笔记

首先分页查询的原理是SQL的limit关键字。

LIMIT 子句用于限制 SQL 查询返回的记录数。它接受一个或两个整数参数,第一个参数表示偏移量,第二个参数表示返回的最大记录数。

我们完全可以使用前端传给我们的page,pageSize,自己去计算limit的参数,但是这样效率很慢。

所以有了分页插件pageHelper.

1 首先引入pageHeper的Maven坐标
复制代码
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
</dependency>
2 在Controller层接受分页请求

主要参数是Page(第几页),PageSize(一页的大小)

java 复制代码
 @GetMapping("/page")
    public Result<PageResult> Page(EmployeePageQueryDTO employeePageQueryDTO)
    {
       PageResult pageResult=employeeService.PageQuery(employeePageQueryDTO);

       return Result.success(pageResult);


    }

这里参数用一个对象接收

3 Service层逻辑处理

PageHepler可以帮助我们计算limit的参数,并同时帮我们把limit加在普通的select语句中,变成分页查询。这样一来执行分页,我们只需要在Mapper配置普通的查询语句,由PageHelper帮我们补上limit所需语句。

page继承了ArrayList,所以它可以接收查询的返回结果,多个数据本身就会返回一个集合。

如果不想用Page,直接使用ArrayList也是可以的,只不过Page有更多的功能,所以pageHeper和Page不是一定要一起使用.看自己的需求选择。

java 复制代码
/**
     * 员工分页查询
     * @param employeePageQueryDTO
     * @return
     */
    @Override
    public PageResult PageQuery(EmployeePageQueryDTO employeePageQueryDTO) {


        // PageHepler可以帮助我们计算limit的参数,并同时帮我们把limit加在普通的select语句中,变成条件查询。
        PageHelper.startPage(employeePageQueryDTO.getPage(),employeePageQueryDTO.getPageSize());

        //执行分页,我们只需要在Mapper配置普通的查询语句,由上面的帮我们补上limit所需语句。
        //page继承了ArrayList,所以它可以接收查询的返回结果,多个数据本身就会返回一个集合。
       //如果不想用Page,直接使用ArrayList也是可以的,只不过Page有更多的功能
         Page<Employee> pages=employeeMapper.PageQuery(employeePageQueryDTO);

         PageResult pageResult=new PageResult();
         pageResult.setRecords(pages.getResult());
      return pageResult;
    }
4 Mapper层的SQL配置

Mapper接口

java 复制代码
 /**
     * 员工分页查询
     * @param employeePageQueryDTO
     * @return
     */
    Page<Employee> PageQuery(EmployeePageQueryDTO employeePageQueryDTO);

Mapper对应SQL

复制代码
<select id="PageQuery" resultType="Employee">
select * from employee
<where>
    <if test="name!=null and name!=''">
      name like concat("%",#{name},"%")
    </if>
</where>

</select>

很明显这里只是一个普通的查询,并没有limit语句,这正是pageHelper的作用,帮我们计算好参数,然后加入SQL语句。

相关推荐
FFF团团员90944 分钟前
树莓派学习笔记3:LED和Button
笔记·学习
Y***h1871 小时前
第二章 Spring中的Bean
java·后端·spring
8***29311 小时前
解决 Tomcat 跨域问题 - Tomcat 配置静态文件和 Java Web 服务(Spring MVC Springboot)同时允许跨域
java·前端·spring
CoderYanger1 小时前
优选算法-栈:67.基本计算器Ⅱ
java·开发语言·算法·leetcode·职场和发展·1024程序员节
碧海潮生_CC1 小时前
【CUDA笔记】04 CUDA 归约, 原子操作,Warp 交换
笔记·cuda
q***06292 小时前
Tomcat的升级
java·tomcat
多多*2 小时前
Java复习 操作系统原理 计算机网络相关 2025年11月23日
java·开发语言·网络·算法·spring·microsoft·maven
青云交2 小时前
Java 大视界 -- Java 大数据在智能物流无人配送车路径规划与协同调度中的应用
java·spark·路径规划·大数据分析·智能物流·无人配送车·协同调度
摇滚侠2 小时前
2025最新 SpringCloud 教程,从单体到集群架构,笔记02
笔记·spring cloud·架构
d***81722 小时前
解决SpringBoot项目启动错误:找不到或无法加载主类
java·spring boot·后端