分页后筛选处理过的数据,再重新进行分页封装

有的时候复杂的数据处理无法再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)

posted @ 2021-12-21 17:28  黄大虾  阅读(2527)  评论(0编辑  收藏  举报