PageHelper 分页无效的坑。。。

砾滩枚举
• 阅读 6259

1.问题

阿里巴巴Java开发手册:

PageHelper 分页无效的坑。。。

1.1.PageHelper先开启分页,后对list数据操作

@Override
public PageInfo<HdQueryVo> getRecordsByView(int pageNo, int pageSize) {
    PageHelper.startPage(pageNo,pageSize);
    List<HdQueryVo> hdQueryVosByView = actionMapper.getActionByView();

    List<HdQueryVo> hdQueryVos = new ArrayList<>();

    for (HdQueryVo hdQueryVo : hdQueryVosByView) {
        HdQueryVo hdQueryVoSingle = new HdQueryVo();
        hdQueryVoSingle.setHdId(hdQueryVo.getHdId());
        hdQueryVoSingle.setHdType(hdQueryVo.getHdType());
        hdQueryVoSingle.setHdTitle(hdQueryVo.getHdTitle());
        hdQueryVoSingle.setHdStartDate(hdQueryVo.getHdStartDate());
        hdQueryVoSingle.setHdEndDate(hdQueryVo.getHdEndDate());
        hdQueryVoSingle.setHdStatus(hdQueryVo.getHdStatus());
        hdQueryVoSingle.setHdImage(hdQueryVo.getHdImage());
        hdQueryVoSingle.setHdNumber(hdQueryVo.getHdNumber());
        hdQueryVoSingle.setGmtCreate(hdQueryVo.getGmtCreate());
        hdQueryVoSingle.setGmtModified(hdQueryVo.getGmtModified());
        hdQueryVoSingle.setUserId(hdQueryVo.getUserId());
        if (hdQueryVo.getHdType().equals(0)) {
            hdQueryVoSingle.setHdJoinUsers(onlineWorksMapper.getOnlineJoinUsers(hdQueryVo.getHdId()));
        } else {
            hdQueryVoSingle.setHdJoinUsers(offlineUsersMapper.getOfflineJoinUsers(hdQueryVo.getHdId()));
        }
        hdQueryVos.add(hdQueryVoSingle);
    }
    PageInfo<HdQueryVo> pageViewInfo = new PageInfo<>(hdQueryVos);

    return pageViewInfo;
}

可以分页,但是数据量错误,total始终等于每页数据量,即pageSize

PageHelper 分页无效的坑。。。

PageHelper 分页无效的坑。。。

1.2.先对list数据进行操作,后开启分页

@Override
public PageInfo<HdQueryVo> getRecordsByView(int pageNo, int pageSize) {
    
    List<HdQueryVo> hdQueryVosByView = actionMapper.getActionByView();

    List<HdQueryVo> hdQueryVos = new ArrayList<>();

    for (HdQueryVo hdQueryVo : hdQueryVosByView) {
        HdQueryVo hdQueryVoSingle = new HdQueryVo();
        hdQueryVoSingle.setHdId(hdQueryVo.getHdId());
        hdQueryVoSingle.setHdType(hdQueryVo.getHdType());
        hdQueryVoSingle.setHdTitle(hdQueryVo.getHdTitle());
        hdQueryVoSingle.setHdStartDate(hdQueryVo.getHdStartDate());
        hdQueryVoSingle.setHdEndDate(hdQueryVo.getHdEndDate());
        hdQueryVoSingle.setHdStatus(hdQueryVo.getHdStatus());
        hdQueryVoSingle.setHdImage(hdQueryVo.getHdImage());
        hdQueryVoSingle.setHdNumber(hdQueryVo.getHdNumber());
        hdQueryVoSingle.setGmtCreate(hdQueryVo.getGmtCreate());
        hdQueryVoSingle.setGmtModified(hdQueryVo.getGmtModified());
        hdQueryVoSingle.setUserId(hdQueryVo.getUserId());
        if (hdQueryVo.getHdType().equals(0)) {
            hdQueryVoSingle.setHdJoinUsers(onlineWorksMapper.getOnlineJoinUsers(hdQueryVo.getHdId()));
        } else {
            hdQueryVoSingle.setHdJoinUsers(offlineUsersMapper.getOfflineJoinUsers(hdQueryVo.getHdId()));
        }
        hdQueryVos.add(hdQueryVoSingle);
    }
    PageHelper.startPage(pageNo,pageSize);
    PageInfo<HdQueryVo> pageViewInfo = new PageInfo<>(hdQueryVos);

    return pageViewInfo;
}

数据可以查询出来,总数total也正确,但是分页功能失效。(这份阿里 Java 开发手册可以关注公众号Java核心技术,回复:手册)

PageHelper 分页无效的坑。。。

PageHelper 分页无效的坑。。。

PageHelper 分页无效的坑。。。

2.原因

PageHelper中startPage开启分页方法只对后面的sql查询起作用

1.1 错误原因是提前开启分页后,对list操作,即PageInfo pageViewInfo = new PageInfo<>(hdQueryVos);

PageHelper 分页无效的坑。。。

/**
* 包装Page对象
*
* @param list
*/
public PageInfo(List list) {
    this(list, 8);
}

只是把list转为PageInfo对象,不影响前面分页数据的操作

1.2 错误原因是先对list操作后,开启翻页后没有sql语句

PageHelper 分页无效的坑。。。

即sql语句没有参与分页查询

3.解决方案

直接对分页后的PageInfo对象中的数据进行操作

  • 对list集合操作,先取出PageInfo里的list集合数据,再对数据进行相关操作
  • 将操作完后的list集合再次存到PageInfo里,进行return

PageHelper 分页无效的坑。。。

PageHelper 分页无效的坑。。。

@Override
public PageInfo<HdQueryVo> getRecordsByView(int pageNo, int pageSize) {
    PageInfo<HdQueryVo> source = PageHelper.startPage(pageNo, pageSize).doSelectPageInfo(()->{
        actionMapper.getActionByView();
    });
    // 需要转换的对象
    PageInfo<HdQueryVo> target = new PageInfo<>();
    // 复制分页属性
    BeanUtils.copyProperties(source, target);
    // 对查询的list进行下一步操作,比如类型转换后
    List<HdQueryVo> collect = source.getList().stream().collect(Collectors.toList());
    List<HdQueryVo> hdQueryVos = new ArrayList<>();

    for (HdQueryVo hdQueryVo : collect) {
        HdQueryVo hdQueryVoSingle = new HdQueryVo();
        hdQueryVoSingle.setHdId(hdQueryVo.getHdId());
        hdQueryVoSingle.setHdType(hdQueryVo.getHdType());
        hdQueryVoSingle.setHdTitle(hdQueryVo.getHdTitle());
        hdQueryVoSingle.setHdStartDate(hdQueryVo.getHdStartDate());
        hdQueryVoSingle.setHdEndDate(hdQueryVo.getHdEndDate());
        hdQueryVoSingle.setHdStatus(hdQueryVo.getHdStatus());
        hdQueryVoSingle.setHdImage(hdQueryVo.getHdImage());
        hdQueryVoSingle.setHdNumber(hdQueryVo.getHdNumber());
        hdQueryVoSingle.setGmtCreate(hdQueryVo.getGmtCreate());
        hdQueryVoSingle.setGmtModified(hdQueryVo.getGmtModified());
        hdQueryVoSingle.setUserId(hdQueryVo.getUserId());
        if (hdQueryVo.getHdType().equals(0)) {
            hdQueryVoSingle.setHdJoinUsers(onlineWorksMapper.getOnlineJoinUsers(hdQueryVo.getHdId()));
        } else {
            hdQueryVoSingle.setHdJoinUsers(offlineUsersMapper.getOfflineJoinUsers(hdQueryVo.getHdId()));
        }
        hdQueryVos.add(hdQueryVoSingle);
    }
    // 加工后的数据放入新的pageinfo
    target.setList(hdQueryVos);

    return target;
}

PageHelper 分页无效的坑。。。

PageHelper 分页无效的坑。。。

PageHelper 分页无效的坑。。。

参考资料:

https://apidoc.gitee.com/free...

https://blog.csdn.net/shangle...

原文链接:https://blog.csdn.net/qq_3508...

版权声明:本文为CSDN博主「He Ain't Hero」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

近期热文推荐:

1.600+ 道 Java面试题及答案整理(2021最新版)

2.终于靠开源项目弄到 IntelliJ IDEA 激活码了,真香!

3.阿里 Mock 工具正式开源,干掉市面上所有 Mock 工具!

4.Spring Cloud 2020.0.0 正式发布,全新颠覆性版本!

5.《Java开发手册(嵩山版)》最新发布,速速下载!

觉得不错,别忘了随手点赞+转发哦!

点赞
收藏
评论区
推荐文章
菜鸟阿都 菜鸟阿都
4年前
pageHelper一对多分页解决方案
前言   pageHelper是一款优秀的Mybatis分页插件,在项目中可以非常便利的使用,使开发效率得到很大的提升,但不支持一对多结果映射的分页查询,所以在平时的使用时,对于一对多分页会出现分页错误,这篇文章主要对pageHelper分页错误进行重现以及提出解决方案。分析    mybatis进行一对多查询时,映射文件(mapper.xml
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
美凌格栋栋酱 美凌格栋栋酱
6个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
Easter79 Easter79
3年前
ssm+PageHelper实现分页查询
通过搭建ssm框架,然后通过mybatis的分页插件pagehelp进行分页查询。源码:https://gitee.com/smfx1314/pagehelper看一下项目结构:!(https://oscimg.oschina.net/oscnet/62738252a25e8c7d8d60f9f9bcf7cb51695.png)首先创建
梦
4年前
微信小程序new Date()转换时间异常问题
微信小程序苹果手机页面上显示时间异常,安卓机正常问题image(https://imghelloworld.osscnbeijing.aliyuncs.com/imgs/b691e1230e2f15efbd81fe11ef734d4f.png)错误代码vardate'2021030617:00:00'vardateT
Stella981 Stella981
3年前
SpringBoot Mybatis解决使用PageHelper一对多分页问题
SpringBootMybatis解决使用PageHelper一对多分页问题参考文章:(1)SpringBootMybatis解决使用PageHelper一对多分页问题(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fwww.codeprj.com%2Fblog%2F
Wesley13 Wesley13
3年前
MyBatis学习总结(17)——Mybatis分页插件PageHelper
如果你也在用Mybatis,建议尝试该分页插件,这一定是最方便使用的分页插件。分页插件支持任何复杂的单表、多表分页,部分特殊情况请看重要提示(http://git.oschina.net/free/Mybatis_PageHelper/blob/master/wikis/Important.markdown)。想要使用分页插件?请看如何使用分页
Stella981 Stella981
3年前
Spring Boot2.X+mybatis+Druid+PageHelper实现多数据源并分页,支持多个字段动态排序,结构层级分明,代码耦合,框架入门
一、SpringBoot整合Mybatis、Druid和PageHelper并实现多数据源和分页,支持多个字段动态排序,其中对分页插件进行了封装,满足于任何场景的开发Druid是一个数据库连接池。Druid可以说是目前最好的数据库连接池!因其优秀的功能、性能和扩展性方面,深受开发人员的青睐。Druid已经在阿里巴巴部署了超过600个应用,经过一年多
Wesley13 Wesley13
3年前
JavaEE——Mybatis(17)
•1、PageHelper插件进行分页 JavaEE——Mybatis(18)MyBatis实用场景1.PageHelper插件分页(https://www.oschina.net/action/GoToLink?urlhttp%3A%2F%2Fwww.cnblogs.com%2FSkyeAngel%2Fp%2F8491741.h
研发日常踩坑-Mysql分页数据重复 | 京东云技术团队
踩坑描述:写分页查询接口,orderby和limit混用的时候,出现了排序的混乱情况在进行第N页查询时,出现与第一前面页码的数据一样的记录。问题在MySQL中分页查询,我们经常会用limit,如:limit(0,20)表示查询第一页的20条数据,limit
砾滩枚举
砾滩枚举
Lv1
人生到处知何似,应似飞鸿踏雪痕。泥上偶然留指爪,鸿飞哪复计西东。
文章
6
粉丝
0
获赞
0