借助PageHelper的PageInfo,实现手动分页

需求:再mysql 查询出数据后,根据数据对List进行进一步处理,现在需要再对List进行分页,所以需要进行手动分页

当list的集合来自多个数据源的时候,所使用的PageHelper就不适合分页查询了,必须要手动分页。
以下是封装的工具类

import com.github.pagehelper.PageInfo;
import java.util.List;

public class PageInfoTool {
    public static <T> PageInfo<T> initPageInfoObj(int currentPage, int total, int pageSize, PageInfo<T> pageInfo, List<T> list) {
        pageInfo.setNextPage(currentPage < ((total + pageSize - 1) / pageSize) ? currentPage + 1 : currentPage);
        pageInfo.setTotal(total);
        pageInfo.setPageSize(pageSize);
        pageInfo.setPageNum(currentPage);
        pageInfo.setPages((total + pageSize - 1) / pageSize);
        pageInfo.setPrePage(currentPage > 1 ? currentPage - 1 : currentPage);
        pageInfo.setIsFirstPage(currentPage == 1 ? true : false);
        pageInfo.setIsLastPage(currentPage == (total + pageSize - 1) / pageSize ? true : false);
        pageInfo.setHasPreviousPage(currentPage == 1 ? false : true);
        pageInfo.setHasNextPage(currentPage == (total + pageSize - 1) / pageSize ? false : true);
        pageInfo.setNavigatePages((total + pageSize - 1) / pageSize);
        int start = 0;
        int end = 0;
        if(pageInfo.getPageNum() == 1){
            start = 0;
            pageInfo.setStartRow(0);
            pageInfo.setHasPreviousPage(false);
            pageInfo.setPrePage(0);
            pageInfo.setIsFirstPage(true);
        }else{
            start = pageInfo.getPageSize()*(pageInfo.getPageNum()-1);
            pageInfo.setStartRow(pageInfo.getPageSize()*(pageInfo.getPageNum()-1));
            pageInfo.setHasPreviousPage(true);
            pageInfo.setPrePage(pageInfo.getPageNum()-1);
            pageInfo.setIsFirstPage(false);
        }
        if((pageInfo.getStartRow()+pageInfo.getPageSize() > pageInfo.getTotal())){
            end = (int) pageInfo.getTotal();
            pageInfo.setEndRow((int) pageInfo.getTotal());
            pageInfo.setHasNextPage(false);
            pageInfo.setIsLastPage(true);
        }else {
            end  = start + pageInfo.getPageSize();
            pageInfo.setEndRow(pageInfo.getStartRow() + pageInfo.getPageSize());
            pageInfo.setHasNextPage(true);
            pageInfo.setNextPage(pageInfo.getPageNum() + 1);
            pageInfo.setIsLastPage(false);
            pageInfo.setEndRow((pageInfo.getPageNum())*pageSize);
        }
        return calcNavigatepageNums(pageInfo,start,end,list);
    }

    private static <T> PageInfo<T> calcNavigatepageNums(PageInfo<T> pageInfo,int start,int end,List<T> list) {
        //当总页数小于或等于导航页码数时
        if (pageInfo.getPages() <= pageInfo.getNavigatePages()) {
            pageInfo.setNavigatepageNums(new int[pageInfo.getPages()]);
            for (int i = 0; i < pageInfo.getPages(); i++) {
                pageInfo.getNavigatepageNums()[i] = i + 1;
            }
        } else { //当总页数大于导航页码数时
            pageInfo.setNavigatepageNums(new int[pageInfo.getNavigatePages()]);
            int startNum = pageInfo.getPageNum() - pageInfo.getNavigatePages() / 2;
            int endNum = pageInfo.getPageNum() + pageInfo.getNavigatePages() / 2;

            if (startNum < 1) {
                startNum = 1;
                //(最前navigatePages页
                for (int i = 0; i < pageInfo.getNavigatePages(); i++) {
                    pageInfo.getNavigatepageNums()[i] = startNum++;
                }
            } else if (endNum > pageInfo.getPages()) {
                endNum = pageInfo.getPages();
                //最后navigatePages页
                for (int i = pageInfo.getNavigatePages() - 1; i >= 0; i--) {
                    pageInfo.getNavigatepageNums()[i] = endNum--;
                }
            } else {
                //所有中间页
                for (int i = 0; i < pageInfo.getNavigatePages(); i++) {
                    pageInfo.getNavigatepageNums()[i] = startNum++;
                }
            }
        }
        if (start < end && end <= pageInfo.getTotal()){
            pageInfo.setList(list.subList(start,end));
        }
        if(pageInfo.getSize() == 0) {
            pageInfo.setStartRow(0);
            pageInfo.setEndRow(0);
        } else {
            pageInfo.setStartRow(pageInfo.getStartRow() + 1);
            pageInfo.setEndRow(pageInfo.getStartRow()-1+pageInfo.getPageSize());
        }
        return pageInfo;
    }

}

需要手动分页时,代码中不要使用以下方法:

PageHelper.startPage(params.getPageNum(),params.getPageSize());

然后将list丢入pageInfo最后执行PageInfoTool中的initPageInfoObj方法

PageInfo<T> pageInfo = new PageInfo<>(sumDataList);
pageInfo = PageInfoTool.initPageInfoObj(params.getPage(),list.size(),params.getPageSize(),pageInfo,list);

这样就实现了手动分页,我的工具类返回的PageResult是经过了封装的,可以根据你们的需求去改造

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CodingPeppa

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值