当前位置:   article > 正文

java-手动分页_java手动分页

java手动分页

java手动分页

1.对list手动分页

适用已查询出所有数据到集合,需要对集合进行手动分页

    public static void main(String[] args) {
        // 造测试数据
        List<String> list = new ArrayList<>();
        Stream.iterate(1, i -> i + 1).limit(123).forEach(i -> list.add(i.toString()));

        // 每页显示的数据条数
        int pageSize = 10;
        // 数据总条数
        int totalPageSize = list.size();
        // 总页数
        int totalPage = (totalPageSize % pageSize) > 0 ? (totalPageSize / pageSize) + 1 : (totalPageSize / pageSize);

        // 一页一页读取数据
        Stream.iterate(1, i -> i + 1).limit(totalPage).forEach(pageIndex -> {
            List<String> collect = list.stream().skip((pageIndex - 1) * pageSize).limit(pageSize).collect(Collectors.toList());
            System.out.println("pageIndex:" + pageIndex+"---"+ collect);
        });
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

在这里插入图片描述

2.对数据量大的数据进行分页执行

适用已知数据库数据量对比较大,指定每次执行条数,一页一页对数据进行分批循环执行

        // 模拟查询出数据库需要执行的总条数
        int total = getPageCount();
        // 每次需要执行的条数
        int runSize = 1000;
        // 计算出需要循环执行的次数
        int runCount = (total % runSize) > 0 ? (total / runSize) + 1 : (total / runSize);
        // 循环执行,按每次需要执行条数一页一页执行
        Stream.iterate(1, i -> i + 1).limit(runCount).forEach(pageIndex -> {
            Page<String> page = querPage(pageIndex, runCount);
            // 业务逻辑代码
        });
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/920790
推荐阅读
相关标签
  

闽ICP备14008679号