使用Node.js通过其唯一的_id更新多个MongoDB对象

时间:2016-01-14 01:02:47

标签: node.js mongodb mongodb-query

基本上我尝试根据其唯一的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,但效率非常低。我相信必须有一个更有效的解决方案来解决这个问题。 非常感谢任何帮助/指导。

1 个答案:

答案 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}}, ...);