首页 > 解决方案 > 更新与 mongodb 中的查询匹配的多个数组元素

问题描述

我正在使用 python 代码更新与查询匹配的数组中的多个元素。这是我的文档结构:

    doc: {
    "userId":327238,
    "assessmentId":115513,
    "institutionId":1632,
    "subjects":[
        {"Id":238,"Included":false,"Rank":1},
        {"Id":239,"Included":true,"Rank":4},
        {"Id":240,"Included":false,"Rank":1},
        {"Id":241,"Included":true,"Rank":10}
     ]
   }

我想仅为具有“包含”的数组元素设置“排名”:0:假。我已经尝试了下面的代码,但它为所有数组元素设置了 'Rank':0 。

 query = {"assessmentId":115513, "institutionId":1632, "subjects":{"$elemMatch":{"Included":false}}}
 update = {"$set":{"subjects.$[].Rank":0}}
 db.test.update_many(query, update)

任何帮助,将不胜感激 。谢谢

标签: pythonarraysmongodbpymongo

解决方案


您需要使用位置运算符 + arrayFilters 如下:

蒙哥壳:

db.test.updateMany( {"doc.assessmentId":115513, "doc.institutionId":1632 } ,{"$set":{"doc.subjects.$[fs].Rank":0}},{arrayFilters:[{"fs.Included":false} ]}  )

Python:

query={"doc.assessmentId":115513, "doc.institutionId":1632 }
update={"$set":{"doc.subjects.$[fs].Rank":0}}
db.test.update_many( query ,update,array_filters=[{"fs.Included":False} ]  )

解释:您在 arrayFilter 中定义变量 fs.Included:false 将用于匹配更新 $set 阶段中的数组对象,并且只有匹配的数组对象的 Rank 设置为 0


推荐阅读