常见的分页方式:
1. 数据全部返给前端,分页功能直接交给前端实现(根据业务场景且仅仅只能用于数据量少的情况)
2. 使用数据库SQL的限制条件,即给搜索语句加上条件,限制查询出来的数据个数(有些业务场景,需要多个联表查询)
3. 使用优秀的插件PageHelper,真的很不错(需要使用在查询语句之前)
4. 代码实现,手动对list 分页。
下面说一下手动分页:
在我们正常开发中, 会遇到特殊的业务场景,比如说需要在代码中对数据进行一些特殊处理, 才能分页。这个时候就需要我们对数据手动分页。
直接上代码(手动分页的工具类,适用于任何场景):
package com.schdri.bimgis.disaster.domain.util; import com.github.pagehelper.PageInfo; import java.util.List; import java.util.stream.Collectors; public class List2PageInfoUtil { /* * Discreption: java8 手动对list分页 * @param: [list, pageNum, pageSize] * @return: com.github.pagehelper.PageInfo<T> * @author: wangm * @date: 2020/5/27 4:30 PM */ public static <T> PageInfo<T> list2PageInfo(Integer pageNum, Integer pageSize, List<T> list) { if (pageNum <= 0) { pageNum = 1; } if (pageSize <= 0) { pageSize = 10; } //java8 stream实现list分页 List<T> pageList = list.stream().skip((pageNum - 1) * pageSize) .limit(pageSize) .collect(Collectors.toList()); PageInfo<T> pageInfo = new PageInfo<T>(pageList); //获取PageInfo其他参数 pageInfo.setTotal(list.size()); int endRow = pageInfo.getEndRow() == 0 ? 0 : (int) ((pageNum - 1) * pageSize + pageInfo.getEndRow() + 1); pageInfo.setEndRow(endRow); boolean hasNextPage = list.size() <= pageSize * pageNum ? false : true; pageInfo.setHasNextPage(hasNextPage); boolean hasPreviousPage = pageNum == 1 ? false : true; pageInfo.setHasPreviousPage(hasPreviousPage); pageInfo.setIsFirstPage(!hasPreviousPage); boolean isLastPage = (list.size() > pageSize * (pageNum - 1) && list.size() <= pageSize * pageNum) ? true : false; pageInfo.setIsLastPage(isLastPage); int pages = list.size() % pageSize == 0 ? list.size() / pageSize : (list.size() / pageSize) + 1; pageInfo.setNavigateLastPage(pages); int[] navigatePageNums = new int[pages]; for (int i = 1; i < pages; i++) { navigatePageNums[i - 1] = i; } pageInfo.setNavigatepageNums(navigatePageNums); int nextPage = pageNum < pages ? pageNum + 1 : 0; pageInfo.setNextPage(nextPage); pageInfo.setPageNum(pageNum); pageInfo.setPageSize(pageSize); pageInfo.setPages(pages); pageInfo.setPrePage(pageNum - 1); pageInfo.setSize(pageInfo.getList().size()); int starRow = list.size() < pageSize * pageNum ? 1 + pageSize * (pageNum - 1) : 0; pageInfo.setStartRow(starRow); return pageInfo; } }
有用就点个赞吧 ~~~~
又是摸鱼的一天~~~~~~