问题描述:
在若以框架中,若依封装的starPage()方法只对该语句后的第一个查询语句进行数据分页,现在在第一次查询后,对对数据进行了数据合并,再分页结束后,返给前端的数据就少了合并的几条。
解决办法:
第一次进行完全查询,然后对数据进行合并,在进行分页。
缺点:每次分页都需要进行一次完全查询。
pageDomain | PageDomain 接收前端的分页信息 |
pageNum,pageSize | 起始索引,每页显示记录数 |
list | 完全查询的list |
list1 | 处理完数据的list |
public TableDataInfo list(SysLogininfor logininfor){
PageDomain pageDomain = TableSupport.buildPageRequest();
Integer pageNum = pageDomain.getPageNum();
Integer pageSize = pageDomain.getPageSize();
//过滤数据
List<SysLogininfor> list = logininforService.selectLogininforList(logininfor);
List<SysLogininfor> list1 = new ArrayList<>();
for (SysLogininfor sysLogininfor : list) {
if(sysLogininfor.getLoginName().equals(sysUser.getLoginName())){
list1.add(sysLogininfor);
}
}
//获取处理好的list集合
int num = list1.size();
list1 = list1.stream().skip((pageNum - 1) * pageSize).limit(pageSize).collect(Collectors.toList());
TableDataInfo rspData = new TableDataInfo();
rspData.setCode(0);
rspData.setRows(list1);
rspData.setTotal(num);
return rspData;
}
启蒙文章:若依框架分页功能对数据进行二次处理 - 码农教程
若依框架---PageHelper分页(一)_若依分页-CSDN博客