【问题标题】:Find Modify and Insert into the Same Collection of MongoDB查找修改并插入到MongoDB的同一个集合中
【发布时间】:2017-09-27 19:42:15
【问题描述】:

谁能帮我解决以下 MongoDB 中的情况:

  1. 从集合 A 中查找具有条件的文档。(假设我们得到了 2 份文件)
  2. 修改这 2 个文档,然后插入到同一集合 A 中,而不会干扰原始 2 个文档。

聚合不支持合并到同一个集合中,我是通过简单的 javascript 得到的,但我们需要在 MapReduce 中。

下面是我的简单脚本:

db.col1.find({
    "field1": "value"
}).forEach(function(d1) {
    d1.f2 = NumberInt(d1.f2 / 10);
    db.col1.save(d1)
})

【问题讨论】:

  • 为什么需要 MapReduce?
  • 正如我之前提到的,我不想干扰原始数据,如果是聚合,那么输出会替换集合数据而不是合并。如果它是 Java 简单脚本,那么数据传输将发生在 App 和 DB 服务器之间。所以我希望它在 map reduce 中在 DB 服务器上执行。

标签: mongodb mapreduce duplicates mongodb-query


【解决方案1】:

在保存修改后的文档 d1 之前,将其 _id 更改为新的 ObjectId(),这将插入新的 d1 而不是更新现有的:

db.col1.find({"field1" : "value"}).forEach(function(d1)
{ 
  d1.f2 = NumberInt(d1.f2/10);
  d1._id = ObjectId(); 
  db.col1.save(d1);
})

【讨论】:

  • 嘿,感谢您的快速回复,但不幸的是,我不是在寻找这种方法。我需要通过使用 Mapreduce 来实现相同的目标。谢谢。
猜你喜欢
  • 1970-01-01
  • 2018-08-31
  • 1970-01-01
  • 2013-11-11
  • 2016-09-22
  • 2019-01-06
  • 2021-06-20
  • 1970-01-01
  • 2017-02-25
相关资源
最近更新 更多