基本上我尝试根据其唯一的objectID(_id)更新Mongo数据库上的多个对象。我尝试了以下但是它们不起作用:
var new_arr = [];
for (var i = 0; i < req.body.length; i++) {
// req.body is an array received from the POST request.
new_arr.push({"_id": new mongodb.ObjectID(req.body[i])})
}
console.log(new_arr);
// new_arr is not accepted since an object is expected.
job_applications.updateMany(
new_arr
,
{
$set: {"application_status": "rejected"}
}, function (err, results) {
console.log(results);
console.log(err);
if (!err) {
console.log('success with reject');
res.sendStatus(200);
}
}
);
我也试过以下但没有运气。
var job_applications = req.app.locals.job_applications;
var new_arr = [];
for (var i = 0; i < req.body.length; i++) {
// req.body is an array of unique IDs (_id)
new_arr.push(new mongodb.ObjectID(req.body[i]))
}
var send_obj = {
"_id": new_arr
};
job_applications.updateMany(
send_obj
,
{
$set: {"application_status": "rejected"}
}, function (err, results) {
console.log(results);
console.log(err);
if (!err) {
console.log('success with reject');
res.sendStatus(200);
}
}
);
我发现这个问题的唯一解决方案是将每个对象的多个updateOne()请求发送到MongoDB,但效率非常低。我相信必须有一个更有效的解决方案来解决这个问题。 非常感谢任何帮助/指导。
答案 0 :(得分:5)
您已接近第二个,但您需要使用$in
查询运算符将_id
与可能值的数组进行匹配:
var new_arr = [];
for (var i = 0; i < req.body.length; i++) {
new_arr.push(new mongodb.ObjectID(req.body[i]))
}
job_applications.updateMany({_id: {$in: new_arr}}, ...);