使用PageHelper在同一个返回值接口中返回数据条数不对

写这篇的原因:

在同一个返回值的接口中调用两次分页,前端调接口发现一次的分页总数total是正常的,另一个是分页设置的一页的数量,别的不显示。

pom中用到的依赖

<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.4.6</version>
</dependency>

如下,代码中用到了两个PageHelper.startPage(pageNo, pageSize);

pageNo, pageSize分别设置了1和10 

PageHelper.startPage(pageNo, pageSize);
        List<AteInterface> ateInterfaces = ateInterfaceService.selectInterfaceList(projectId);
        PageHelper.startPage(pageNo, pageSize);
        List<JSONObject> allSfrtestTitleData = ateSfrInterService.findSfrtestTitleData(projectName);
        

        resultMap.put("ateInterface", new PageInfo<>(ateInterfaces));
        resultMap.put("ateTestTitle", new PageInfo<>(allSfrtestTitleData));

前端调用后只有ateInterfaces的total是数据库查出来的条数,而allSfrtestTitleData的值不管数据库查出来多少条,它只显示10条。

解决方案:

1.将上面提到的两个查询放到两个接口中,不放在一个接口,就不会有冲突的现象

2.如果必须要在一个接口中带给前端,需要第二个的分页需要手动写一个类,然后调用之后进行分页,手动分页的util如下:

package com.wonsec.cc.Utils;

import com.github.pagehelper.PageInfo;

import java.util.List;
import java.util.stream.Collectors;

/**
 * @author Administrator
 * @version 1.0
 * @description: 数据实现手动分页
 * @date 2024/7/16 20:55
 */

public class PageInfoUtil {
    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;
    }
}

调用时的操作:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值