双层for循环中包含查询的优化

      简单描述下,之前写了一些很是糟糕的代码,比如双层for循环中,内部执行了查询(没错,循环跟数据库交互哇嘎嘎,数据量稍微多一些,那就要等待一些时间啦),这两天闲下来了开始回看代码,然后又改了一个版本,觉得速度提高啦。现在记录下

未改动之前,主要代码结构如下

双层for循环中包含查询的优化_第1张图片

改动过程

显而易见这个recordList是目标对象的一个集合。因为只是用它的id,for循环中每次拿一个id来查,这样对数据库压力很大,速度慢,我就把这个集合使用lambda 取出来里面所有对象的id字段生成了一个新的集合,比如这样

recordIdList = recordList.stream().map(item -> item.getId()).collect(Collectors.toList());

然后查询数据的话就一次性全部查询出来,比如这样

wpdWrapper.in("record_id", recordIdList);//等于  eg : ...... where id in('','','','')

然后我把查询出来的这个WorkPlanDataModel的集合进行分组,按照这个对象的某个字段,我这块是按照recordId(业务需求)

比如这样(java8有相应的写法,我此处使用了underscore的第三方库)

Map> groupMap = U.groupBy(dataList,
                    new Function() {
                        public String apply(WorkPlanDataModel dataModel) {
                            return dataModel.getRecordId();
                        }
                    } else {
                        resMap.put(templateId, workPlanDataModel.getValue());
                    });

然后我再去组装操作数据,返回前端,改造完成后速度提升可观,前端转圈圈加载时间明显缩短。

总结:

       多思考,都动脑。

 

 

 

你可能感兴趣的:(javaweb)