I need to update several documents by providing them in the body. I can't query them, they must be provided.
我需要通过在正文中提供几个文档来更新它们。我无法查询它们,必须提供它们。
Example:
例:
var persons = [
{id: 1, name'Joe', active: false},
{id:2, name:'Jane', active: false})
];
This data is provided in the body and I want to set the active property to false.
这个数据在正文中提供,我想将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)
};
This code feels no good. Is there any better query to do this? I don't find any in the docs.
这段代码感觉不错。有没有更好的查询来做到这一点?我在文档中找不到任何内容。
1 个解决方案
#1
19
Try using the update command along with the "$in" operator:
尝试使用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) { ... });
Hope this helps
希望这可以帮助
#1
19
Try using the update command along with the "$in" operator:
尝试使用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) { ... });
Hope this helps
希望这可以帮助