首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >MongoDB - 更新集合中所有记录的最快方法是什么?

MongoDB - 更新集合中所有记录的最快方法是什么?
EN

Stack Overflow用户
提问于 2018-12-10 05:50:19
回答 2查看 0关注 0票数 0

我有一个有900万条记录的集合。我目前正在使用以下脚本来更新整个集合:

simple_update.js

代码语言:javascript
复制
db.mydata.find().forEach(function(data) {
  db.mydata.update({_id:data._id},{$set:{pid:(2571 - data.Y + (data.X * 2572))}});
});

这是从命令行运行,如下所示:

代码语言:javascript
复制
mongo my_test simple_update.js

所以我所做的就是根据简单的计算添加一个新的字段pid

有更快的方法吗?这需要很长时间。

EN

回答 2

Stack Overflow用户

发布于 2018-12-10 13:52:52

你可以做两件事。

  1. 发送“multi”标志设置为true的更新。
  2. 存储功能服务器端并尝试使用服务器端代码执行。

该链接还包含以下建议:

这是执行批量管理工作的好方法。在服务器上运行mongo,通过localhost接口连接。然后连接非常快且延迟低。这比db.eval()更友好,因为db.eval()会阻止其他操作。

这可能是你得到的最快的。您必须意识到在单个服务器上发布9M更新将是一项繁重的操作。假设您可以获得3k更新/秒,您仍然在谈论运行近一个小时。

这不是一个“mongo问题”,这将是一个硬件限制。

票数 0
EN

Stack Overflow用户

发布于 2018-12-10 15:04:31

我使用的是:db.collection.update方法

代码语言:javascript
复制
// db.collection.update( criteria, objNew, upsert, multi ) // --> for reference
db.collection.update( { "_id" : { $exists : true } }, objNew, upsert, true);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/-100008930

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档