简单描述下,之前写了一些很是糟糕的代码,比如双层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());
});
然后我再去组装操作数据,返回前端,改造完成后速度提升可观,前端转圈圈加载时间明显缩短。
总结:
多思考,都动脑。