PageHelper 分页无效的坑。。。
点击关注公众号,Java干货及时送达
1.问题
![](https://filescdn.proginn.com/34a011e9d553c5876cbee0f157b332a2/c6fb717b3475b80ddc5206847a97f230.webp)
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
![](https://filescdn.proginn.com/257a42d5352269d2e3b503b727944c27/3a7e05b70f3c8cc888384be51bbb4ddd.webp)
![](https://filescdn.proginn.com/62d30850d506debaf91aba6b116627a2/2ae86e6cc91ae79d9d82595b865e23ed.webp)
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核心技术,回复:手册)
![](https://filescdn.proginn.com/51ab724c00534487caca881422c34b74/5c5a3457fcfbb38f267bd16636583adc.webp)
![](https://filescdn.proginn.com/0ad94be6cf7260ebc2db506eaf155816/c2e5a0ff898e6888cdb825a00aac684d.webp)
![](https://filescdn.proginn.com/bbf87043d745562dd43de094b982540c/652165f6de90765c7ef8bb0941faab58.webp)
2.原因
PageHelper中startPage开启分页方法只对后面的sql查询起作用。另外,关注公众号Java技术栈,在后台回复:面试,可以获取我整理的 Java 系列面试题和答案,非常齐全。
1.1 错误原因是提前开启分页后,对list操作,即PageInfo pageViewInfo = new PageInfo<>(hdQueryVos);
![](https://filescdn.proginn.com/941abf1c549a50a9e7693747b9707aff/4f23d1129e6be478a08854211c60208f.webp)
/**
* 包装Page对象
*
* @param list
*/
public PageInfo(List list) {
this(list, 8);
}
只是把list转为PageInfo对象,不影响前面分页数据的操作。Spring Boot 学习笔记,分享给你。
1.2 错误原因是先对list操作后,开启翻页后没有sql语句
![](https://filescdn.proginn.com/9f5c8946574c0861340b03da969adc19/36d4002f23a232f62628891962be4078.webp)
即sql语句没有参与分页查询。
3.解决方案
直接对分页后的PageInfo对象中的数据进行操作
对list集合操作,先取出PageInfo里的list集合数据,再对数据进行相关操作 将操作完后的list集合再次存到PageInfo里,进行return
![](https://filescdn.proginn.com/50a2f14b0f3655ef45673839f005a417/86bba8fbbbe485cf27b42a1a09807885.webp)
![](https://filescdn.proginn.com/88a6b601e5fca96fb7d3f9cff06b335a/f5eff3f2dc41538abceafcb99e2e91d4.webp)
@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;
}
![](https://filescdn.proginn.com/889647463e2ebb254dfa8074a82054db/613fa50cffb5ee1032b35253087a5981.webp)
![](https://filescdn.proginn.com/62d30850d506debaf91aba6b116627a2/2ae86e6cc91ae79d9d82595b865e23ed.webp)
![](https://filescdn.proginn.com/47425a06670186b24cbec99fa043c0f1/af3e1f9638ba152ff448d4272bed5747.webp)
原文链接:https://blog.csdn.net/qq_35080796/article/details/105508744
参考资料:
版权声明:本文为CSDN博主「He Ain't Hero」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
![](https://filescdn.proginn.com/f33dc96f544b3e3355b964e270a90cf3/4a436334c715b89743945cf9fbc23c44.webp)
![](https://filescdn.proginn.com/2b96e7987992e450af74045748abb8b5/202529f85687d2576f8ef8adbb36b7e5.webp)
![](https://filescdn.proginn.com/7585d4dcb30e2ba6e9bbef49a84261b0/5624a94c80ed3cfaec948bbaa1532568.webp)
![](https://filescdn.proginn.com/a11ded4786f66262251feda2e8563759/da1b5cce7e085189aaf9d73aecd63018.webp)
![](https://filescdn.proginn.com/ac8d7a7feaee627edcd896c678ce734d/3fddd68d6a1fa036be3b2dc5259defae.webp)
关注Java技术栈看更多干货
![](https://filescdn.proginn.com/cc4091ea7e80fa23dfc877253968d4e6/8b62896a53e601cbb5b451fff16526df.webp)
评论