首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >FindAndModify,返回对象数组

FindAndModify,返回对象数组
EN

Stack Overflow用户
提问于 2015-02-27 13:51:17
回答 1查看 2K关注 0票数 2

我试图用findAndModify修改多个文档,然后返回修改后的新文档。我的问题是:

代码语言:javascript
复制
db.users.findAndModify({
  query: {
    _id: {
      $in: [
        ObjectId("54061f3c27afac4b44688c1d"),
        ObjectId("54061f3c27afac4b44688c1e")
      ]
    }
  },
  update: {
    $inc: {
      i: 1
    }
  },
  new: true
});

但只能检索一个文档。我的目标是修改多个文档,并将它们全部返回。是否有可能检索一组文档?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-02-27 14:04:37

正如此页在文档中解释的那样,findAndModify“修改并返回单个文档”。如果要使用findAndModify修改多个文档,则每个文档必须运行一次。在mongo shell中,您可以使用一些JavaScript实现这一点,如下所示:

代码语言:javascript
复制
var oids = [ObjectId("54061f3c27afac4b44688c1d"),
            ObjectId("54061f3c27afac4b44688c1e")];
docs = [];
for (var i in oids) {
    id = oids[i];
    doc = db.e.findAndModify({
        "query": { "_id": id },
        "update": { "$inc": { "i": 1 }},
        "new": true
    });
    docs.push(doc);
}
printjson(docs);

另一个选项是使用update作为选项运行multi,然后检索文档。您的代码如下所示:

代码语言:javascript
复制
db.users.update(
    { "_id": {
        "$in": [ObjectId("54061f3c27afac4b44688c1d"),
                ObjectId("54061f3c27afac4b44688c1e")]
        }
    },
    { "$inc": { "i": 1 }},
    { "multi": true }
);
db.users.find(
    { "_id": {
        "$in": [ObjectId("54061f3c27afac4b44688c1d"),
                ObjectId("54061f3c27afac4b44688c1e")]
        }
    }
);
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28766668

复制
相关文章

相似问题

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