一种数据分页方法

工作中对数据进行分页的场景很常见,分享一种分页方法

private static <T> List<T> startPage(List<T> list, Integer pageNumber, Integer pageSize) {
		if (list == null || list.size() == 0) {
			return new ArrayList<>();
		}
		int count = list.size(); // 记录总数
		int pageCount = 0; // 页数
		if (count % pageSize == 0) {
			pageCount = count / pageSize;
		} else {
			pageCount = count / pageSize + 1;
		}
		int fromIndex = 0; // 开始索引
		int toIndex = 0; // 结束索引
		if (!pageNumber.equals(pageCount)) {
			fromIndex = (pageNumber - 1) * pageSize;
			toIndex = fromIndex + pageSize;
		} else {
			fromIndex = (pageNumber - 1) * pageSize;
			toIndex = count;
		}
		return list.subList(fromIndex, toIndex);
	}

如果对数据实时性要求不高,建议分页前对全量数据做缓存,避免每次获取全量数据导致接口耗时,特别是查询DB的操作。


版权声明:本文为CY071512原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。