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

1.问题


阿里巴巴Java开发手册

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

@Override

public PageInfo getRecordsByView(int pageNo, int pageSize) {

PageHelper.startPage(pageNo,pageSize);

List hdQueryVosByView = actionMapper.getActionByView();

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);

}

PageInfo pageViewInfo = new PageInfo<>(hdQueryVos);

return pageViewInfo;

}

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

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

@Override

public PageInfo getRecordsByView(int pageNo, int pageSize) {

List hdQueryVosByView = actionMapper.getActionByView();

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);

}

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

总结:心得体会

既然选择这个行业,选择了做一个程序员,也就明白只有不断学习,积累实战经验才有资格往上走,拿高薪,为自己,为父母,为以后的家能有一定的经济保障。

学习时间都是自己挤出来的,短时间或许很难看到效果,一旦坚持下来了,必然会有所改变。不如好好想想自己为什么想进入这个行业,给自己内心一个答案。

面试大厂,最重要的就是夯实的基础,不然面试官随便一问你就凉了;其次会问一些技术原理,还会看你对知识掌握的广度,最重要的还是你的思路,这是面试官比较看重的。

最后,上面这些大厂面试真题都是非常好的学习资料,通过这些面试真题能够看看自己对技术知识掌握的大概情况,从而能够给自己定一个学习方向。包括上面分享到的学习指南,你都可以从学习指南里理顺学习路线,避免低效学习。

大厂Java架构核心笔记(适合中高级程序员阅读):

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
试真题能够看看自己对技术知识掌握的大概情况,从而能够给自己定一个学习方向。包括上面分享到的学习指南,你都可以从学习指南里理顺学习路线,避免低效学习。

大厂Java架构核心笔记(适合中高级程序员阅读):

[外链图片转存中…(img-YzLZU9QK-1712182852327)]

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值