专栏名称: 程序员鱼皮
鹅厂全栈开发,持续分享编程技法和实用项目
目录
相关文章推荐
闹闹每日星运  ·  终极老实人,说谎自心疼 ·  17 小时前  
朱志良博士de职业健康  ·  噪声聋诊断的另一个客观检查(ABR/BAEP ... ·  23 小时前  
朱志良博士de职业健康  ·  噪声聋诊断的另一个客观检查(ABR/BAEP ... ·  23 小时前  
火石创造  ·  1月生物医药产业投融资分析及Top30项目( ... ·  2 天前  
闹闹每日星运  ·  星历0208:仙女注意说话分寸 天秤保护个人隐私 ·  5 天前  
51好读  ›  专栏  ›  程序员鱼皮

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

程序员鱼皮  · 公众号  ·  · 2024-03-21 14:41

正文

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

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

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

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

示例代码:

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

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

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

List userIdList = modelList.stream()
        .map(Model::getUserId)
        .collect(Collectors.toList());
List users = userService.listByIds(userIdList);
Map> 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 | 优雅统计耗时







请到「今天看啥」查看全文