纯净、安全、绿色的下载网站

首页|软件分类|下载排行|最新软件|IT学院

当前位置:首页IT学院IT技术

Java PageHelper分页无效 Java中PageHelper分页后对list操作导致分页无效

He Ain''''t Hero   2021-05-25 我要评论
想了解Java中PageHelper分页后对list操作导致分页无效的相关内容吗He Ain''''t Hero在本文为您仔细讲解Java PageHelper分页无效的相关知识和一些Code实例欢迎阅读和指正我们先划重点:Java,PageHelper,分页无效,PageHelper分页下面大家一起来学习吧

1.问题

阿里巴巴Java开发手册

在这里插入图片描述

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

在这里插入图片描述

在这里插入图片描述

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也正确但是分页功能失效

在这里插入图片描述

在这里插入图片描述

**加粗样式**

2.原因

PageHelper中startPage开启分页方法只对后面的sql查询起作用

1.1 错误原因是提前开启分页后对list操作即PageInfo pageViewInfo = new PageInfo<>(hdQueryVos);

在这里插入图片描述

/**
* 包装Page对象
*
* @param list
*/
public PageInfo(List list) {
this(list, 8);
}

只是把list转为PageInfo对象不影响前面分页数据的操作

1.2 错误原因是先对list操作后开启翻页后没有sql语句

在这里插入图片描述

即sql语句没有参与分页查询

3.解决方案

直接对分页后的PageInfo对象中的数据进行操作
①对list集合操作先取出PageInfo里的list集合数据再对数据进行相关操作
②将操作完后的list集合再次存到PageInfo里进行return

在这里插入图层

在这里插入图片描述

@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;
    }

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

参考资料:

PageHelper官方文档
PageHelper分页查询结果后再对数据List操作的方法


相关文章

猜您喜欢

  • 微信小程序贪吃蛇游戏 微信小程序实现贪吃蛇游戏

    想了解微信小程序实现贪吃蛇游戏的相关内容吗Hello world&&在本文为您仔细讲解微信小程序贪吃蛇游戏的相关知识和一些Code实例欢迎阅读和指正我们先划重点:微信小程序,贪吃蛇下面大家一起来学习吧..
  • Java动态代理 浅谈Java动态代理的实现

    想了解浅谈Java动态代理的实现的相关内容吗晓之木初在本文为您仔细讲解Java动态代理的相关知识和一些Code实例欢迎阅读和指正我们先划重点:Java动态代理的实现,java动态代理下面大家一起来学习吧..

网友评论

Copyright 2020 www.fresh-weather.com 【世纪下载站】 版权所有 软件发布

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 点此查看联系方式