通过在body,mongoose/mongodb中提供文档来更新多个文档

Joe*_*Joe 11 mongoose mongodb node.js mongodb-query

我需要通过在正文中提供几个文档来更新它们.我无法查询它们,必须提供它们.

例:

 var persons = [
    {id: 1, name'Joe', active: false}, 
    {id:2, name:'Jane', active: false})
];
Run Code Online (Sandbox Code Playgroud)

这个数据在正文中提供,我想将active属性设置为false.

exports.setActivePropertyOnPersons = function(input,callback){
  for(var i = 0;i<input.body.length;i++){
    mongoose.model('person').findOne({id:input.body[i].id}, function(err, person){
      person.active = false;
      person.save();
    })
  }
  callback.send(200)
};
Run Code Online (Sandbox Code Playgroud)

这段代码感觉不错.有没有更好的查询来做到这一点?我在文档中找不到任何内容.

Pro*_*ome 20

尝试使用update命令和" $ in "运算符:

var ids= [];
for (var i=0 i<input.body.length; ++i) {
    ids.push(input.body[i].id);
}

mongoose.model('person').update( {id : {"$in":ids}}, {active:false} , {multi: true} , function(err,docs) { ... });
Run Code Online (Sandbox Code Playgroud)

希望这可以帮助

  • 这是使用`$ in`选择多个文档的基本方法,但是[`.update()`](http://docs.mongodb.org/manual/reference/method/db.collection.update/ )命令需要["multi"](http://docs.mongodb.org/manual/reference/method/db.collection.update/#multi-parameter)参数才能实际更改超过匹配的第一个文档. (4认同)
  • 你将如何处理活动变量中的不同值? (2认同)