PageHelper分页失效问题(通过List流操作和手动分页来解决)

项目场景:

        在公司项目中,成绩查询的业务中有点逻辑在内,需要数据显示两层数据结构和数据筛选和处理,web端需要分页显示,前端展示组件是饿了么UI(Element UI),Java后端接口分页插件使用的是PageHelper


问题描述和分析

        问题描述:PageHelper.startPage(page,pageSize);分页的前提条件就是这条语句放在定义返回结果集前面,但是最后Response返回PageInfo的时候分页失效了,返回多少条显示多少条数据。

       分析原因:返回的结果集内容做了筛选或添加逻辑处理后发生了改变,而PageHelper.startPage源码中有一个参数DEFAULT_COUNT默认为true,前提条件就是结果集内容不变才有效

ServiceImpl中:

    @Override
    public ResponseResult getStudentScoreList(String search, Integer page, Integer pageSize, UserDetails userInfo) {
        PageHelper.startPage(page, pageSize);
        //查询班级下的所以学生
        List scoreVOList = studentMapper.getStudentScoreStatus(search,userInfo.getId());
        /**
         *此处省略,中间对结果集合做了内容处理
         **/
        return ResponseResult.success(new PageInfo<>(scoreVOList));
    }

解决方案:

通过List流操作和手动PageInfo分页解决,如下:

ServiceImpl中:

    @Override
    public ResponseResult getStudentScoreList(String search, Integer page, Integer pageSize, UserDetails userInfo) {
        //查询班级下的所以学生
        List scoreVOList = studentMapper.getStudentScoreStatus(search,userInfo.getId());
        /**
         *此处省略,中间对结果集合做了内容处理
         **/
        //计算总记录数
        int total = scoreVOList.size();
        //pageHelper无效,手动分页,流操作:sorted排序、skip跳记录和limit限制显示记录数
        List collect = scoreVOList
                        .stream()
                        .sorted(Comparator.comparingInt(StudentScore::getGainPoint))
                        .skip((page - 1) * pageSize)
                        .limit(pageSize)
                        .collect(Collectors.toList());
        //计算总页数
        int pageSum = total % pageSize == 0 ? total / pageSize : total / pageSize + 1;
        PageHelper.startPage(page, pageSize);
        PageInfo scorePageInfo = new PageInfo<>(collect);
        //总记录数
        scorePageInfo.setTotal(total);
        //总页数
        scorePageInfo.setPages(pageSum);
        //清除分页缓存
        Pagehelper.clearPage();
        return ResponseResult.success(scorePageInfo);
    }

  

结束语:随心所欲不逾矩,无节制的放纵通常误以为是自由,其实已被欲望所奴役

你可能感兴趣的:(JAVA开发,bug,java,spring,boot,maven,开发语言)