使用findOneAndUpdate()更新两个不同属性时的MongoDB语法

时间:2018-11-14 19:23:07

标签: mongodb

当我想使用相同的findOneAndUpdate()更新两个单独的属性时,我正在尝试确定正确的MongoDB语法。这就是我所拥有的(并且它只是更新第一个属性:

await Agency.findOneAndUpdate(
  {
    historicId: data.id_number
  },
  {
    $set: {
      "authorizations.supervisor": authorizationsSupervisor,
      $push: {
        "authorizations.policy": firstPolicyObj,
        "authorizations.policy": secondPolicyObj,
        "authorizations.policy": thirdPolicyObj
      }
    }
  },
  {
    returnNewDocument: true
  }
);

构造此语法的正确方法是什么?

文档模型如下:

{
   _id: <ObjectId>,
   otherProp: <value>,
   authorizations: {
     supervisor: <ObjectId>,
     department: <value>,
     policy: [ 
       {
         category: <value>,
         requirements: [
           {},
           {}
         ]
       }
     ]
   }
}

1 个答案:

答案 0 :(得分:1)

$set: {
         "authorizations.supervisor": authorizationsSupervisor,
      },
$push: { 
        "authorizations.policy": { $each: [ firstPolicyObj, secondPolicyObj, thirdPolicyObj] 
      }