Java 集合实现分页的方法(业务代码实现分页)

 更新时间:2025年02月07日 10:57:08   作者:初夏0811  
在Java开发中,有些场景比较复杂,受限制,不好在sql查询层面实现分页,需要在查询的list结果后,将list分页返回,如何实现呢,带着这个问题一起通过本文学习吧

一、前言

在Java开发中,有些场景比较复杂,受限制,不好在sql查询层面实现分页,需要在查询的list结果后,将list分页返回,如何实现呢?

二、代码实现

1、假设有一个 list集合,元素如下:

ArrayList<Integer> list = Lists.newArrayList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

2、使用 subList 实现分页:

/**
 *@Description: subList 分页
 * <br> 1. 起始位置边界值处理: 当前页码 <= 0 情况处理; 当前页码 > 最大页码 情况处理
 * <br> 2. 终止位置边界值处理: 当前页码 <= 0 情况处理; 终止位置 <= 总记录数  情况处理
 * @param pageSize 每页显示的数量
 * @param pageNum  当前页码
 */
private List<?> subList(ArrayList<?> list, int pageSize, int pageNum) {
    int count = list.size(); // 总记录数
    // 计算总页数
    int pages = count % pageSize == 0 ? count / pageSize : count / pageSize + 1;
    // 起始位置
    int start = pageNum <= 0 ? 0 : (pageNum > pages ? (pages - 1) * pageSize : (pageNum - 1) * pageSize);
    // 终止位置
    int end = pageNum <= 0 ? (pageSize <= count ? pageSize : count) : (pageSize * pageNum <= count ? pageSize * pageNum : count);
    return list.subList(start, end);
}

3、Java8 Stream 分页

/**@Description: Java8 Stream 分页
 * <br> 1. 起始位置边界值处理: 同 subList 方法
 * <br> 2. 终止位置:无需处理,会自动处理边界问题
 *  @param pageSize 每页显示的数量
 *  @param pageNum  当前页码
 */
private List<?> subListJava8(ArrayList<?> list, int pageSize, int pageNum) {
    int count = list.size(); // 总记录数
    // 计算总页数
    int pages = count % pageSize == 0 ? count / pageSize : count / pageSize + 1;
    // 起始位置
    int start = pageNum <= 0 ? 0 : (pageNum > pages ? (pages - 1) * pageSize : (pageNum - 1) * pageSize);
    // 终止位置
    int end = pageSize ;
    return list.stream().skip(start).limit(pageSize).collect(Collectors.toList());
}

4、使用 Lists 工具类的 partition 分页

/**@Description: 使用 Lists 工具类的 partition 分页
 * <br> 1. 页码边界值处理:小于等于0,情况处理; 页码大于 (总页数-1) 情况处理
 * <br> 2. 总页数-1 ,原因是:list集合索引是从0开始的。
 *  @param pageSize 每页显示的数量
 *  @param pageNum  当前页码
 * @see com.google.common.collect.Lists#partition(java.util.List, int)
 */
private List<?> partition(ArrayList<?> list, int pageSize, int pageNum) {
    // 将 List 按照 PageSzie 拆分成多个List
    List<? extends List<?>> partition = Lists.partition(list, pageSize);
    // 总页数
    int pages = partition.size();
    pageNum = pageNum <= 0 ? 0 : (pageNum <= (pages - 1) ? pageNum : (pages - 1));
    return partition.get(pageNum);
}

三、总结

以上不管哪种方式实现分页,对性能都会有一定的影响,尤其是数据量越大,性能越差,因为其原理是全表扫描,将所有数据查询出来后,再在内存中进行分页返回,在可能的情况下,尽量想想如何在sql查询时实现分页返回才好。

到此这篇关于Java 集合实现分页-业务代码实现分页的文章就介绍到这了,更多相关Java 集合实现分页内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • spring cloud内容汇总(各个功能模块、启动、部署)的详细过程

    spring cloud内容汇总(各个功能模块、启动、部署)的详细过程

    Spring Cloud 是一套基于 Spring Boot 的框架集合,用于构建分布式微服务架构,文章介绍了Spring Cloud框架及其相关工具的使用,还详细介绍了如何配置和使用这些功能,包括配置文件、依赖管理以及实际应用示例,感兴趣的朋友一起看看吧
    2024-11-11
  • SpringBoot隐式参数注入的码优雅升级指南

    SpringBoot隐式参数注入的码优雅升级指南

    这篇文章主要为大家详细介绍了SpringBoot中隐式参数注入的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2026-03-03
  • SpringMVC中redirect重定向(带参数)的3种方式

    SpringMVC中redirect重定向(带参数)的3种方式

    Spring MVC中做form表单功能提交时,防止用户客户端后退或者刷新时重复提交问题,需要在服务端进行重定向跳转,本文主要介绍了SpringMVC中redirect重定向(带参数)的3种方式,感兴趣的可以了解一下
    2024-07-07
  • 关于MyBatis通用Mapper@Table注解使用的注意点

    关于MyBatis通用Mapper@Table注解使用的注意点

    这篇文章主要介绍了关于MyBatis通用Mapper@Table注解使用的注意点,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • JDK26中LazyConstant的具体使用

    JDK26中LazyConstant的具体使用

    LazyConstant是JDK26之后引入的新属性,是一个延迟常量,之前的JDK25中的StableValue已经移除了,改成这个了,它本质是一个持有不可变数据的容器,能够实现对象的按需初始化,下面就来详细的介绍一下
    2026-05-05
  • Java 抽象类详解

    Java 抽象类详解

    抽象类是用abstract关键字修饰的类,其核心作用是作为父类提供通用模板,同时强制子类实现特定方法,本文介绍Java 抽象类的相关知识,感兴趣的朋友跟随小编一起看看吧
    2026-03-03
  • Java版仿QQ验证码风格图片验证码

    Java版仿QQ验证码风格图片验证码

    这篇文章主要为大家分享了java图片验证码实例代码,感兴趣的小伙伴们可以参考一下
    2016-04-04
  • 详解Java中clone的写法

    详解Java中clone的写法

    这篇文章主要介绍了Java中clone的写法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-07-07
  • Java实现按行分割大文件

    Java实现按行分割大文件

    这篇文章主要为大家详细介绍了Java实现按行分割大文件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • 在SpringBoot项目中优雅的连接多台Redis的操作方法

    在SpringBoot项目中优雅的连接多台Redis的操作方法

    本文将基于一个实际案例,详细介绍如何在Spring Boot中优雅地配置和使用多个Redis实例,解决常见的注入歧义问题,并提供一个通用的Redis工具类来简化操作,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧
    2025-09-09

最新评论