双层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());
                    });
  • 然后我再去组装操作数据,返回前端,改造完成后速度提升可观,前端转圈圈加载时间明显缩短。

三、总结

       多思考,多动脑。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值