2024年PageHelper分页后,对list操作会导致分页无效(2),掌门一对一java面试流程

总结

三个工作日收到了offer,头条面试体验还是很棒的,这次的头条面试好像每面技术都问了我算法,然后就是中间件、MySQL、Redis、Kafka、网络等等。

  • 第一个是算法

关于算法,我觉得最好的是刷题,作死的刷的,多做多练习,加上自己的理解,还是比较容易拿下的。

而且,我貌似是将《算法刷题LeetCode中文版》、《算法的乐趣》大概都过了一遍,尤其是这本

《算法刷题LeetCode中文版》总共有15个章节:编程技巧、线性表、字符串、栈和队列、树、排序、查找、暴力枚举法、广度优先搜索、深度优先搜索、分治法、贪心法、动态规划、图、细节实现题

最新出炉,头条三面技术四面HR,看我如何一步一步攻克面试官?

《算法的乐趣》共有23个章节:

最新出炉,头条三面技术四面HR,看我如何一步一步攻克面试官?

最新出炉,头条三面技术四面HR,看我如何一步一步攻克面试官?

  • 第二个是Redis、MySQL、kafka(给大家看下我都有哪些复习笔记)

基本上都是面试真题解析、笔记和学习大纲图,感觉复习也就需要这些吧(个人意见)

最新出炉,头条三面技术四面HR,看我如何一步一步攻克面试官?

  • 第三个是网络(给大家看一本我之前得到的《JAVA核心知识整理》包括30个章节分类,这本283页的JAVA核心知识整理还是很不错的,一次性总结了30个分享的大知识点)

最新出炉,头条三面技术四面HR,看我如何一步一步攻克面试官?

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

来源:blog.csdn.net/qq_35080796/article/details/105508744

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

}

写在最后

还有一份JAVA核心知识点整理(PDF):JVM,JAVA集合,JAVA多线程并发,JAVA基础,Spring原理,微服务,Netty与RPC,网络,日志,Zookeeper,Kafka,RabbitMQ,Hbase,MongoDB,Cassandra,设计模式,负载均衡,数据库,一致性哈希,JAVA算法,数据结构,加密算法,分布式缓存,Hadoop,Spark,Storm,YARN,机器学习,云计算…

image

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

[外链图片转存中…(img-2kKMXAG4-1715004569428)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值