今日代码 PK | 避免循环查库

在后端开发中,循环查库可以说是一种忌讳,因为与数据库的 IO 交互是十分耗时的行为。

特别是使用云数据库时,不仅有磁盘 IO ,还有网络 IO。

因此我们往往会采用一些策略来避免循环查库。

但是新手往往会忘记这个点,写出不规范的代码,

示例代码:

for (ModelVO model : modelList) {
    User user = userService.getById(model.getUserId());
    model.setUser(user);
}

list里的数据比较多的情况下,执行个几十秒都有可能。

我们可以改写成这样,示例代码:

List<Long> userIdList = modelList.stream()
        .map(Model::getUserId)
        .collect(Collectors.toList());
List<User> users = userService.listByIds(userIdList);
Map<Long, List<User>> idUserMap = users.stream()
        .collect(Collectors.groupingBy(User::getId));
modelList.forEach(model -> model.setUser(idUserMap.get(model.getUserId())));

这样就避免了循环查库(上面的代码缺少了判空逻辑,大家自行完善)。

你都是使用什么方法来避免循环查库呢?欢迎投票并在评论区留下自己的做法。

完整代码片段来源于代码小抄,欢迎点击进入小程序阅读!

在线访问:https://www.codecopy.cn/post/gl930t

更多优质代码欢迎进入小程序查看!

往期推荐

今日代码 PK | 使用 Optional 判空

今日代码 PK | Java 使用正则表达式

今日代码 PK | 优雅统计耗时

今日代码 PK | 日期时间处理

今日代码大赏 | MyBatis-Plus 优雅查询


相关推荐

  • 教你一招,保护你的项目代码!
  • JDK22 发布!
  • 端到端加速企业GenAI创新,英伟达NIM微服务成为软件企业看中的亮点!
  • 巨头争锋:AGI来到临界点?
  • 突发!Stability AI核心团队已分崩离析,抢功、侵权、撤资争议不断,AI界有自己的“春山学”
  • 使用 BigDL-LLM 加速 Intel * 数据中心 GPU 上的 LLM 推理
  • 裁员潮持续,劝所有程序员早点做个人规划!| 极客时间
  • Sora很难跟进?微调就不是一个岗位?大力出奇迹将继续适用?大模型将对软件生态带来哪些变化?
  • 没有App,也没有 App Store,未来的手机会干掉全部应用开发人员吗?
  • 杭州/深圳内推 | VIVO影像算法研究部招聘AIGC+计算摄影方向算法工程师/实习生
  • 港科大(广州)开源智慧交通新成果,用AI大模型控制红绿灯
  • 能否在追问中坚持判断?揭秘大语言模型的判断一致性挑战
  • 最新爆料!GPT-5已有客户上手体验:性能惊人,或将在夏天发布
  • Transformer七子重聚GTC,老黄亲自赠送签名版DGX-1!7年奠基之作背后佚事揭秘
  • 瘫痪8年小哥植入马斯克脑机接口,狂打8小时「文明6」!Neuralink首个人类植入者直播来了
  • 中国AI开发者「抢人战」倒计时2天!IEEE首位中国籍副主席、OpenAI大佬齐聚,2024 GDC大会来了
  • Zilliz联手英伟达发布全球首个GPU加速向量数据库!CUDA加持性能飙升50倍,未来十年或暴涨1000倍
  • qiankun?这次我选了wujie!
  • CVPR 2024 | 一统所有目标感知任务,华科&字节提出目标感知基础模型GLEE
  • CMU朱俊彦、Adobe新作:512x512图像推理,A100只用0.11秒