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

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

双层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());
                    });

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

总结:

       多思考,都动脑。

 

 

 

相关文章:

  • 2022-12-23
  • 2022-01-09
  • 2022-12-23
  • 2022-12-23
  • 2021-12-15
  • 2021-06-18
  • 2022-12-23
猜你喜欢
  • 2021-11-29
  • 2022-12-23
  • 2022-12-23
  • 2022-02-24
  • 2021-07-04
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案