今日代码 PK | 避免循环查库
程序员鱼皮
共 1519字,需浏览 4分钟
· 2024-04-12
在后端开发中,循环查库可以说是一种忌讳,因为与数据库的 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
更多优质代码欢迎进入小程序查看!
往期推荐
评论
C++核心准则ES.86:避免在基本for循环的循环体中修改循环控制变量
ES.86: Avoid modifying loop control variables inside the body of raw for-loopsES.86:避免在基本for循环的循环体中修改循环控制变量Reason(原因)The loop control up front should enable correct reasoning a...
面向对象思考
0
替代for循环,让Python代码更pythonic !
来源:Python 技术「ID: pythonall」 为什么要挑战自己在代码里不写 for loop?因为这样可以迫使你去学习使用比较高级、比较地道的语法或 library。文中以 python 为例子,讲了不少大家其实在别人的代码里都见过、但...
恋习Python
0
替代 for 循环,让 Python 代码更 pythonic !
↓ 推荐关注↓ 加入 城哥知识星球 ,解惑答疑,告别迷茫 为什么要挑战不在代码中使用for循环呢?因为这样可以促使你学习使用更高级、更地道的语法或库。以 Python 为例,本文介绍了许多大家其实在别人的代码里都见过、...
Python学习与数据挖掘
0