写这篇的原因:
在同一个返回值的接口中调用两次分页,前端调接口发现一次的分页总数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条。
解决方案:
标签:pageNum,分页,pageSize,pageInfo,list,PageHelper,条数,返回值,PageInfo From: https://blog.csdn.net/smokeblue/article/details/1405227541.将上面提到的两个查询放到两个接口中,不放在一个接口,就不会有冲突的现象
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; } }
调用时的操作: