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);
});
}
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);
// 业务逻辑代码
});