List<AccessAreaVo> areaVo = vos.stream()
.skip(pageable.getPageSize() * (pageable.getPageNumber() - 1))
.limit(pageable.getPageSize()).collect(Collectors.toList());
阿里巴巴nacos源码里面的分页
services = doPage(services, pageNo - 1, pageSize);
private Collection<Service> doPage(Collection<Service> services, int pageNo, int pageSize) { if (services.size() < pageSize) { return services; } Collection<Service> result = new LinkedList<>(); int i = 0; for (Service each : services) { if (i++ < pageNo * pageSize) { continue; } result.add(each); if (result.size() >= pageSize) { break; } } return result; }
final int startRow = (pageNo - 1) * pageSize;
selectSql = sqlFetchRows + " LIMIT " + startRow + "," + pageSize;