PageHelper分页失效,只能查出第一页

PageHelper分页失效,只能查出第一页

  • 1. 现象
  • 2. 原因
  • 3. PageHelper工作原理

1. 现象

  1. 分页代码如下:

    		int pageId = Constants.ONE;boolean isHasNextPage;do {PageHelper.startPage(pageId, Constants.DEFAULT_PAGE_SIZE);List<String> projectIdList = marketingConsStageDAO.getAllProjectId();PageInfo<String> pageInfo = new PageInfo<>(projectIdList);// 此处省略业务逻辑isHasNextPage = pageInfo.isHasNextPage();pageId++;} while (isHasNextPage);
    
  2. marketingConsStageDAO.getAllProjectId()代码如下:

    public List<String> getAllProjectId() {Weekend<MarketingConsStage> weekend = Weekend.of(MarketingConsStage.class, true, true);weekend.selectProperties("projectId");weekend.setDistinct(true);return marketingConsStageMapper.selectByExample(weekend).stream().map(MarketingConsStage::getProjectId).collect(Collectors.toList());}
    
  3. marketingConsStageDAO.getAllProjectId()应该返回两万余条数据,因此预期do-while循环会执行很多次,但是发现第一页的isHasNextPage就为false,无法继续执行do-while循环;

2. 原因

  1. 进行debug,将断点打到

    PageInfo<String> pageInfo = new PageInfo<>(projectIdList);
    

    这一行,然后发现返回的projectIdListArrayList类型;在这里插入图片描述

  2. 看一下PageInfo的构造方法:

    		/*** 包装Page对象** @param list          page结果* @param navigatePages 页码数量*/public PageInfo(List<T> list, int navigatePages) {super(list);if (list instanceof Page) {Page page = (Page) list;this.pageNum = page.getPageNum();this.pageSize = page.getPageSize();this.pages = page.getPages();this.size = page.size();//由于结果是>startRow的,所以实际的需要+1if (this.size == 0) {this.startRow = 0;this.endRow = 0;} else {this.startRow = page.getStartRow() + 1;//计算实际的endRow(最后一页的时候特殊)this.endRow = this.startRow - 1 + this.size;}} else if (list instanceof Collection) {this.pageNum = 1;this.pageSize = list.size();this.pages = this.pageSize > 0 ? 1 : 0;this.size = list.size();this.startRow = 0;this.endRow = list.size() > 0 ? list.size() - 1 : 0;}if (list instanceof Collection) {calcByNavigatePages(navigatePages);}}
    
  3. 可以看到,由于projectIdListArrayList类型,因此在创建pageInfo对象时,总页数直接走了this.pages = this.pageSize > 0 ? 1 : 0;的逻辑,导致分页失效;

  4. 如果我们将

    .stream()
    .map(MarketingConsStage::getProjectId)
    .collect(Collectors.toList());
    

    操作放到分页查询操作外面,将代码修改为:

    		int pageId = Constants.ONE;boolean isHasNextPage;do {PageHelper.startPage(pageId, Constants.DEFAULT_PAGE_SIZE);List<MarketingConsStage> marketingConsStageList = marketingConsStageDAO.getAllProjectId();PageInfo<MarketingConsStage> pageInfo = new PageInfo<>(marketingConsStageList);List<String> projectIdList = marketingConsStageList.stream().map(MarketingConsStage::getProjectId).collect(Collectors.toList());// 此处省略业务逻辑isHasNextPage = pageInfo.isHasNextPage();pageId++;} while (isHasNextPage);
    

    marketingConsStageDAO.getAllProjectId()修改为:

    public List<MarketingConsStage> getAllProjectId() {Weekend<MarketingConsStage> weekend = Weekend.of(MarketingConsStage.class, true, true);weekend.selectProperties("projectId");weekend.setDistinct(true);return marketingConsStageMapper.selectByExample(weekend);}
    

    然后debug就会发现,marketingConsStageList是一个Page类型变量,此时分页功能就正常了;在这里插入图片描述

3. PageHelper工作原理

  1. PageHelper是一个MyBatis分页插件,它可以帮助我们在查询数据的时候进行分页处理。当我们调用PageHelper.startPage(pageNum, pageSize)方法时,它会在底层使用ThreadLocal来保存当前线程的分页参数,然后通过拦截器对SQL语句进行改写,从而实现分页查询。
  2. 在我们调用完PageHelper.startPage(pageNum, pageSize)方法后,紧接着执行的SQL查询语句会被PageHelper拦截并进行改写,从而在查询结果的时候只返回指定页数和每页记录数的数据。PageHelper会将查询结果封装成一个Page对象,这个Page对象包含了查询结果的总记录数、当前页数、每页记录数以及查询结果的数据列表。
  3. 因此,当我们调用查询方法后,返回的list可以被PageHelper包装成Page对象。这是因为PageHelper在底层对查询结果进行了封装,将查询结果以Page对象的形式返回给了调用方。调用方可以通过Page对象获取查询结果的各种信息,如总记录数、当前页数、每页记录数等,同时也可以通过Page对象获取查询结果的数据列表。
  4. 总之,通过PageHelper实现分页查询的过程可以概括为:开启分页查询 -> 执行查询操作 -> 将查询结果列表返回给调用方,并以Page对象的形式包装 -> 调用方通过Page对象获取分页查询的各种信息。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/3016.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【SCI一区】【电动车】基于ADMM双层凸优化的燃料电池混合动力汽车研究(Matlab代码实现)

目录 &#x1f4a5;1 概述 1.2 电动车动力学方程 1.3 电池模型 &#x1f4da;2 运行结果 &#x1f389;3 参考文献 &#x1f308;4 Matlab代码、数据、文章讲解 &#x1f4a5;1 概述 文献来源&#xff1a; 随着车辆互联性的出现&#xff0c;互联汽车 (CVs) 在增强道路安全、改…

数学建模-图论 最短路径

作图 %% 注意&#xff1a;以下代码需要较新版本的matlab才能运行&#xff08;最好是2016版本及以上哦&#xff09; % 如果运行出错请下载新版的matlab代码再运行%% Matlab作无向图 % &#xff08;1&#xff09;无权重&#xff08;每条边的权重默认为1&#xff09; % 函数graph(…

ES(2)基本使用

文章目录 创建索引查询索引查询 shopping索引查询所有索引 删除索引数据操作添加查询查询指定id数据 查询所有数据修改完全覆盖局部修改 删除 复杂查询操作条件查询根据字段名和值查询对应数据全量查询分页查询显示指定字段排序查询 多条件查询must&#xff08;and&#xff09;…

spring复习:(29)MutablePropertyValues

该类通过成员变量 propertyValueList 来保存多个PropertyValue对象。 public class MutablePropertyValues implements PropertyValues, Serializable {private final List<PropertyValue> propertyValueList;Nullableprivate Set<String> processedProperties;pr…

SQL进阶(2)——SQL语句类型 增删改查CRUD 事务初步 表关联关系 视图 +索引

目录 引出SQL语句类型1.DML数据操纵语言&#xff08;重点&#xff09;2.DQL数据查询语言&#xff08;重点&#xff09;3.DDL(Data Definition Language了解)4.DCL(Data Control Language了解)5.TCL 事务控制语言 运算符和其他函数1.运算符2.其它函数增删改查CRUD 视图索引事务1…

基于Python的用户和项目协同过滤算法实现与解析——以余弦相似度和最近邻居为基础的推荐系统构建

基于Python的用户和项目协同过滤算法实现与解析——以余弦相似度和最近邻居为基础的推荐系统构建 摘要 本篇文章主要讲解如何使用Python来编写基于用户的协同过滤算法和基于项目的协同过滤算法。我们首先了解这两种协同过滤算法的概念和原理,接着通过Python代码实现这两种算…

如何克服Leetcode做题的困境

文章目录 如何克服Leetcode做题的困境问题背景克服困境的建议实践与理论结合切忌死记硬背分析解题思路不要过早看答案迭代式学习寻求帮助坚持与耐心查漏补缺 结论 如何克服Leetcode做题的困境 问题背景 明明自觉学会了不少知识&#xff0c;可真正开始做Leetcode题目时&#x…

内存参数问题导致内存溢出

问题&#xff1a;内存参数问题导致内存溢出 1、文件过大&#xff0c;进行分块 2、 运行参数&#xff0c;使用最大内存配置2时&#xff0c;导致空指针异常。 3、获取详细报错信息-内存溢出 多线程捕获Throwable异常 修改代码&#xff0c;捕获Throwable&#xff0c;获取异常 异…

vue中预览pdf

情况一 如果后端返回的pdf地址&#xff0c;粘贴到浏览器的url框中&#xff0c;可以在浏览器中直接进行预览的&#xff0c;那么我们就用window.open&#xff0c;或 a标签&#xff0c;或iframe标签通过设置src进行预览即可 法1&#xff1a;可以直接使用window.open&#xff08;…

leetcode100.相同的树

⭐️ 题目描述 &#x1f31f; leetcode链接&#xff1a;相同的树 1️⃣ 代码&#xff1a; bool isSameTree(struct TreeNode* p, struct TreeNode* q){// 判断两棵树当前结点是否为空if (p NULL && q NULL) {// 说明是相同的return true;}// 来到这里有几种情况// …

【裸辞转行】是告别,也是新的开始

一年多了没有更新&#xff0c;是因为去年身体加心理因素辞职了&#xff0c;并且大概率不会再做程序员了&#xff0c;嗯。本来觉得可能再也不会打开 CSDN 了&#xff0c;想了想&#xff0c;还是来做个告别吧&#xff0c;任何事情都该有始有终才对。 回忆碎碎念 是在去年的 11 …

【实战篇】docker-compose部署go项目

一、场景&#xff1a; 二、需求 三、实操 Stage 1&#xff1a;GoLand 中 build 生成二进制文件 Stage 2&#xff1a;编写 Dockerfile Stage 3&#xff1a;编写 docker-compose.yaml Stage 4&#xff1a;文件上传到 ubuntu 服务器上&#xff0c;并设置文件读写权限 Stage…

前端 | (二)各种各样的常用标签 | 尚硅谷前端html+css零基础教程2023最新

学习来源&#xff1a;尚硅谷前端htmlcss零基础教程&#xff0c;2023最新前端开发html5css3视频 文章目录 &#x1f4da;HTML排版标签&#x1f4da;HTML语义化标签&#x1f4da;块级元素与行内元素&#x1f4da;文本标签&#x1f407;常用的文本标签&#x1f407;不常用的文本标…

erlang 虚拟机优化参数

sbwt none 将CPU忙等待关闭将有助于降低系统显示的CPU使用率&#xff0c;因为开启了忙等待的BEAM&#xff0c;CPU负载并不代表真实的工作情况&#xff1b; K true 开启epoll IO模型 swt low Sets scheduler wakeup threshold. Defaults to medium. The thresh…

Kubernetes Service的过程

文章目录 Kubernetes Service的实现基础内容1. 命令 ip route show table all2. DNAT3. IPVS和iptables4. Service Service的实现简述 Kubernetes Service的实现 基础内容 在了解Service之前,需要先了解一些额外的知识: 命令: ip route show table allDNATIPVS和iptables基础…

idea不小心push的文件夹怎么处理?

第一种方式&#xff0c;把不小心push上去的人解决掉。 第二种方式&#xff0c;以我自身为例&#xff0c;同事不小心push了.idea文件夹 首先打开git bash git rm --cached .idea/ -r 然后查看一下状态 git status 接着提交修改 git commit -m "cancel track .idea file&q…

【Redis】高可用之三:集群(cluster)

本文是Redis系列第6篇&#xff0c;前5篇欢迎移步 【Redis】不卡壳的 Redis 学习之路&#xff1a;从十大数据类型开始入手_AQin1012的博客-CSDN博客关于Redis的数据类型&#xff0c;各个文章总有些小不同&#xff0c;我们这里讨论的是Redis 7.0&#xff0c;为确保准确&#xf…

linux编程-telnet

我是使用WSL的linux系统与主机windows系统进行通信。 1.安装telnet linux&#xff1a; 在终端中运行以下命令&#xff1a; sudo apt-get install telnet windows&#xff1a; 在命令行中运行以下命令&#xff1a; DISM /Online /Enable-Feature /FeatureName:TelnetClien…

【代码随想录刷题记录】 647. 回文子串 、 516.最长回文子序列

647. 回文子串 1、题目 给你一个字符串 s &#xff0c;请你统计并返回这个字符串中 回文子串 的数目。 题目链接&#xff1a;https://leetcode.cn/problems/palindromic-substrings/ 2、代码 class Solution { public: //判断字符串是否为回文bool IsPalindrome(string s, …

Linux基础(三)端口、进程及主机状态管理、环境变量、文件管理

目录 端口 nmap netstat 进程管理 查看进程 关闭进程 主机状态监控 系统资源top命令 磁盘信息监控 网络状态监控 环境变量 $符号 自己设置环境变量 自定义环境变量PATH Linux的文件和下载 压缩和解压 tar命令 zip和unzip命令 端口 每个电脑有一个ip地址&#xff…