使用 javascript 地图中的值更新 mongo collection

Update mongo collection with values from a javascript map

我有一个 collection 看起来像这样

[
   {
      "project":"example1",
      "stores":[
         {
            "id":"10"
            "name":"aa",
            "members":2
         }
      ]
   },
   {
      "project":"example2",
      "stores":[
         {
            "id":"14"
            "name":"bb",
            "members":13
         },
         {
            "id":"15"
            "name":"cc",
            "members":9
         }
      ]
   }
]

我想更新 stores 数组的字段成员,从 Map 中获取新值,例如这个

0:{"10" => 201}
1:{"15" => 179}

预期结果是:

[
       {
          "_id":"61",
          "stores":[
             {
                "id":"10"
                "name":"aa",
                "members":201
             }
          ]
       },
       {
          "_id":"62",
          "stores":[
             {
                "id":"14"
                "name":"bb",
                "members":13
             },
             {
                "id":"15"
                "name":"cc",
                "members":179
             }
          ]
       }
    ]

使用 javascript/typescript 实现此目的的选项是什么?

您可以使用 Mongoes 模型的 update() 函数来更新您期望的文档。 尝试以下一个:

const keyValArray= [{"10": 201},{"15":"179"}];
db.collectionName.update({_id: givenId},
       { $push: { "stores": {$each: keyValArray} }},
       function(err, result) {
          if(err) {
             // return  error
          }
          //return success
       }
});

最后,我通过使用映射中的值更新原始数据库实体对象来解决,然后我生成了一个批量查询。

for (let p of projects) {
    for(let s of p.stores) { 
        if(storeUserCount.has(s.id)){
            s.members = storeUserCount.get(s.id);
        }
    };
    bulkQueryList.push({ 
        updateOne: {
            "filter": { "_id": p._id },
            "update": { "$set": {"stores": p.stores} }
        }});
};

await myMongooseProjectEntity.bulkWrite(bulkQueryList);