偌依框架的分页失效改用手动作分页

标题一:先说一下为什么会分页失效

从代码层面来分析一下

java 复制代码
public TableDataInfo extremum(@RequestBody HashMap<String, Object> param){
        Integer pageNum = Integer.valueOf(param.get("pageNum").toString());
        Integer pageSize = Integer.valueOf(param.get("pageSize").toString());

		/**在这使用了偌依的代码分页线程*/
        startPage(pageNum, pageSize);
        /**该线程被作用在了该list集合上,对象被消耗了*/
        List<TrendVibrationReport> list = new ArrayList<>();
        try {
            list = trendVibrationReportService.selectMapListExtremum(param);
        }catch (Exception e){
            e.printStackTrace();
        } finally {
            if (list == null || list.size() == 0){
                return getDataTable(new ArrayList<>());
            }
        }
		/**重新拼接出了另外一个集合,上面的分页线程被消耗了,就不可以再进行分页了*/
        List<HashMap<String, Object>> hashMapList = new ArrayList<>();
        try {
            hashMapList = trendVibrationReportService.selectMapListExtremumTow(list);
        }catch (Exception e){
            e.printStackTrace();
        } finally {
            if (hashMapList == null || hashMapList.size() == 0){
                return getDataTable(new ArrayList<>());
            }
        }

        return getDataTable(hashMapList, list);
    }

上面通过代码和注解可以看到失效的原因。

2.如何解决的呢?

我采用的是手动进行的分页操作,当然办法也有很多,可以使用mybatispuls自带的分页等等。。。

java 复制代码
public TableDataInfo extremum(@RequestBody HashMap<String, Object> param){

        List<TrendVibrationReport> list = trendVibrationReportService.selectMapListExtremum(param);

        if (list == null || list.size() == 0){
            return new TableDataInfo();
        }

        List<HashMap<String, Object>> hashMapList = new ArrayList<>();
        try {
            hashMapList = trendVibrationReportService.selectMapListExtremumTow(list);
        }catch (Exception e){
            e.printStackTrace();
        }

        if (hashMapList == null || hashMapList.size() == 0){
            return new TableDataInfo();
        }

        // 手动分页
        long pageNum = Integer.valueOf(param.get("pageNum").toString());
        long pageSize = Integer.valueOf(param.get("pageSize").toString());
        // 总共条数
        int num = hashMapList.size();
        /**该方法是把所有的数据查出后在内存中进行的分页截取,对于特别大的数据量还是有一定的不友好的。*/
        hashMapList = hashMapList.stream().skip((pageNum - 1) * pageSize).limit(pageSize).collect(Collectors.toList());
        TableDataInfo rspData = new TableDataInfo();
        rspData.setCode(HttpStatus.SUCCESS);
        rspData.setRows(hashMapList);
        rspData.setTotal(num);
        return rspData;
    }

hashMapList = hashMapList.stream().skip((pageNum - 1) * pageSize).limit(pageSize).collect(Collectors.toList());

使用的是stream()流,然后截取,再用转为集合,具体的java8的新特性可以私下学学真的很有用。

相关推荐
Dola_Pan1 小时前
Linux文件IO(二)-文件操作使用详解
java·linux·服务器
wang_book1 小时前
Gitlab学习(007 gitlab项目操作)
java·运维·git·学习·spring·gitlab
蜗牛^^O^2 小时前
Docker和K8S
java·docker·kubernetes
从心归零3 小时前
sshj使用代理连接服务器
java·服务器·sshj
IT毕设梦工厂4 小时前
计算机毕业设计选题推荐-在线拍卖系统-Java/Python项目实战
java·spring boot·python·django·毕业设计·源码·课程设计
Ylucius4 小时前
动态语言? 静态语言? ------区别何在?java,js,c,c++,python分给是静态or动态语言?
java·c语言·javascript·c++·python·学习
七夜zippoe5 小时前
分布式系统实战经验
java·分布式
是梦终空5 小时前
JAVA毕业设计176—基于Java+Springboot+vue3的交通旅游订票管理系统(源代码+数据库)
java·spring boot·vue·毕业设计·课程设计·源代码·交通订票
落落落sss5 小时前
sharding-jdbc分库分表
android·java·开发语言·数据库·servlet·oracle
码爸5 小时前
flink doris批量sink
java·前端·flink