java 如何实现手动分页(适用于任何场景)

文章介绍了常见的分页方法,包括数据全量返回前端处理、数据库SQL限制、使用PageHelper插件以及代码手动分页。特别强调了手动分页的情况,提供了一个Java8利用StreamAPI进行分页的工具类代码,适用于任何场景,包括设置PageInfo的相关参数。
摘要由CSDN通过智能技术生成
常见的分页方式:


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;
    }
}

有用就点个赞吧 ~~~~

又是摸鱼的一天~~~~~~

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值