PageHelper分页后,对list操作会导致分页无效

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

List 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 pageViewInfo = new PageInfo<>(hdQueryVos);

return pageViewInfo;

}

数据可以查询出来,总数total也正确,但是分页功能失效。(搜索公众号Java知音,回复“2021”,送你一份Java面试题宝典)

2.原因


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

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

/**

* 包装Page对象

* @param list

*/

public PageInfo(List list) {

this(list, 8);

}

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

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

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

3.解决方案


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

  • 对list集合操作,先取出PageInfo里的list集合数据,再对数据进行相关操作

  • 将操作完后的list集合再次存到PageInfo里,进行return

@Override

public PageInfo getRecordsByView(int pageNo, int pageSize) {

PageInfo source = PageHelper.startPage(pageNo, pageSize).doSelectPageInfo(()->{

actionMapper.getActionByView();

});

// 需要转换的对象

PageInfo target = new PageInfo<>();

// 复制分页属性

BeanUtils.copyProperties(source, target);

// 对查询的list进行下一步操作,比如类型转换后

List collect = source.getList().stream().collect(Collectors.toList());

List 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分页查询结果后再对数据List操作的方法

推荐好文
强大,10k+点赞的 SpringBoot 后台管理系统竟然出了详细教程!
分享一套基于SpringBoot和Vue的企业级中后台开源项目,代码很规范!
能挣钱的,开源 SpringBoot 商城系统,功能超全,超漂亮

最后

手绘了下图所示的kafka知识大纲流程图(xmind文件不能上传,导出图片展现),但都可提供源文件给每位爱学习的朋友

image.png

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!
c686a13f077b2673b3057e179e664.png)

最后

手绘了下图所示的kafka知识大纲流程图(xmind文件不能上传,导出图片展现),但都可提供源文件给每位爱学习的朋友

[外链图片转存中…(img-Y104pIwT-1714645485476)]

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值