PageHelper分页后对list集合操作

PageHelper分页后对list集合操作

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操作的方法

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: PageHelper是Mybatis的分页插件,可以对List集合进行分页。使用方法如下: 1. 在项目中导入PageHelper的依赖。 2. 在Mybatis的配置文件中配置PageHelper插件。 3. 在需要分页的查询语句前调用PageHelper.startPage(pageNum,pageSize)方法。 4. 执行查询语句。 5. 将查询结果转换为Page类型。 例如: ``` PageHelper.startPage(1, 10); List<User> users = userMapper.selectAll(); PageInfo<User> pageInfo = new PageInfo<>(users); ``` 在这个例子中,第1页的前10条数据将会被查询出来,并且封装到PageInfo对象中。 ### 回答2: PageHelper是一款优秀的开源分页插件,能够对Java中的List集合进行分页处理,大大降低了我们在开发过程中分页操作的难度,提高了我们的开发效率。 使用PageHelper进行List集合分页,首先要在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>5.1.11</version> </dependency> ``` 然后在需要进行分页的方法中添加分页代码: ```java // 设置分页参数,pageNum为当前页数,pageSize为每页显示数量 PageHelper.startPage(pageNum, pageSize); // 执行List集合查询操作 List<Entity> listData = getDataFromDatabase(); // 进行分页处理 PageInfo<Entity> pageInfo = new PageInfo<>(listData); ``` 通过以上代码,我们就可以使用PageHelperList集合进行分页处理,并将查询结果封装在PageInfo对象中,方便我们进行数据的展示和处理。 PageHelper通过拦截和重写MyBatis中的SQL语句,实现了对查询结果的分页处理。当我们使用PageHelper进行分页操作时,它会自动为我们生成对应的SQL语句,包含查询总数和分页信息。因此,在使用PageHelper时,我们不需要手动进行总数查询和分页处理,减少了我们的工作量。 总之,PageHelper是我们在进行Java开发时非常实用的一款分页插件,通过对List集合进行分页处理,可以快速方便地完成我们的开发需求,提高我们的开发效率和质量。 ### 回答3: PageHelper是一款开源的MyBatis分页插件,它可以在不修改原有的SQL语句的基础上,通过拦截器的方式实现对数据的分页操作PageHelper支持的常见数据库类型有MySQL、Oracle、PostgreSQL和SQL Server等,而且这些数据库所使用的SQL语法也是不同的,但是它们都可以被PageHelper所支持。 PageHelper对于一个List集合分页操作相当简单,只需要在查询时引入PageHelper并设置分页参数,就可以自动将查询结果封装为一个Page对象,其中包含分页信息和数据列表。具体操作过程如下: 1. 在需要进行分页查询的方法中,引入PageHelper插件,并设置分页参数,例如: ``` //引入PageHelper插件 PageInfo<Employee> pageInfo = PageHelper.startPage(pageNum, pageSize) .doSelectPageInfo(() -> employeeMapper.selectAll()); ``` 这段代码表示在调用selectAll方法时使用PageHelper进行拦截,并将分页信息封装为一个Page对象。其中pageNum和pageSize表示当前页数和每页显示的条数,可以通过前端传参或者从配置文件中读取。selectAll方法是从数据库中查询出所有的数据,并通过lambda表达式的方式返回一个List集合。 2. 在DAO接口中添加selectAll方法,例如: ``` @Select("select * from employee") List<Employee> selectAll(); ``` 这段代码是通过注解的方式,在employee表中查询出所有的数据,与第1步中的doSelectPageInfo方法构成了一个完整的分页查询操作。 3. 将分页信息和数据列表返回给前端,例如: ``` //将分页信息和数据列表返回给前端 Map<String, Object> result = new HashMap<>(); result.put("total", pageInfo.getTotal()); result.put("pageNum", pageInfo.getPageNum()); result.put("pageSize", pageInfo.getPageSize()); result.put("list", pageInfo.getList()); return result; ``` 这段代码将Page对象中的分页信息和数据列表取出来,并以Map对象的形式返回给前端,其中total表示总记录数,pageNum表示当前页数,pageSize表示每页显示的条数,list表示当前页的数据列表。 总的来说,PageHelper对于List集合分页操作比较简单,只需要在查询时引入插件并设置分页参数,就可以自动将查询结果封装为一个Page对象,而且该插件还支持多种数据库类型和SQL语法,使得分页操作更加灵活。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值