一、说明
双层for循环中,内部执行了查询(没错,循环跟数据库交互哇嘎嘎,数据量稍微多一些,那就要等待一些时间啦)
这两天闲下来了开始回看代码,然后又改了一个版本,觉得速度提高啦。现在记录下
未改动之前,原代码如下,注意看循环中查询数据库
二、改动过程
- 显而易见这个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<String, List<WorkPlanDataModel>> groupMap = U.groupBy(dataList, new Function<WorkPlanDataModel, String>() { public String apply(WorkPlanDataModel dataModel) { return dataModel.getRecordId(); } } else { resMap.put(templateId, workPlanDataModel.getValue()); });
- 然后我再去组装操作数据,返回前端,改造完成后速度提升可观,前端转圈圈加载时间明显缩短。
三、总结
多思考,多动脑。