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