有的时候复杂的数据处理无法再sql中进行处理,需要查出来之后再筛选去除不要的数据,这时需要重新封装分页数据进行返回。
建议处理方法:查询时先不要拼接分页语句,查出全部的数据之后再来筛选处理,处理完list数据之后再用下面的工具类进行封装
/** * 自定义List分页工具 * @author hanwl */ public class PageUtil { /** * 开始分页 * @param list * @param pageNum 页码 * @param pageSize 每页多少条数据 * @return */ public static List startPage(List list, int pageNum, int pageSize) { if (list == null) { return null; } if (list.size() == 0) { return null; } 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 (pageNum != pageCount) { fromIndex = (pageNum - 1) * pageSize; toIndex = fromIndex + pageSize; } else { fromIndex = (pageNum - 1) * pageSize; toIndex = count; } List pageList = list.subList(fromIndex, toIndex); return pageList; } }
原文地址:Java对list进行分页,subList()方法实现分页 - 霞光里 - 博客园 (cnblogs.com)