前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >今日代码 PK | 避免循环查库

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

作者头像
程序员鱼皮
发布2024-03-25 17:47:38
1040
发布2024-03-25 17:47:38
举报
文章被收录于专栏:鱼皮客栈鱼皮客栈

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

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

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

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

示例代码:

代码语言:javascript
复制
for (ModelVO model : modelList) {
    User user = userService.getById(model.getUserId());
    model.setUser(user);
}

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

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

代码语言:javascript
复制
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

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2024-03-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序员鱼皮 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档