当前位置: 代码网 > it编程>编程语言>Java > Java 集合实现分页的方法(业务代码实现分页)

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

2025年02月08日 Java 我要评论
一、前言在java开发中,有些场景比较复杂,受限制,不好在sql查询层面实现分页,需要在查询的list结果后,将list分页返回,如何实现呢?二、代码实现1、假设有一个 list集合,元素如下:arr

一、前言

在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 集合实现分页内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com