Arrays 如何在mongo中更新文档子数组中的字段

Arrays 如何在mongo中更新文档子数组中的字段,arrays,mongodb,mongodb-query,Arrays,Mongodb,Mongodb Query,在包含这些文档的数据库中 { "_id" : ObjectId("5448f241e47010336375bb21"), "lid" : "Ridali", "items" : [ { "product" : "dogfood", , "done" : false }

在包含这些文档的数据库中

{
        "_id" : ObjectId("5448f241e47010336375bb21"),
        "lid" : "Ridali",
        "items" : [
                {
                        "product" : "dogfood",        ,
                        "done" : false
                }
        ],
}
{
        "_id" : ObjectId("5448fc15e47010336375bb23"),
        "lid" : "Qitula",
        "items" : [
                {
                        "product" : "measure kitchen cab",
                        "done" : false,
                        "tags" : [
                                "11x30"
                        ]
                },
                {
                        "product" : "radiators",
                        "done" : true
                },
                {
                        "product" : "dogfood",
                        "done" : true
                }                
        ],
}
如何将
lid:“Qitula”
dogfood
更新为
catfood
?我尝试过不同的方法

db.lists.update({lid: "Qitula","items: {$elemMatch: {product: "dogfood"}}},{$set: {"items.product": "catfood"}})
没有成功

db.lists.update({lid: "Qitula","items.product": "dogfood" }, { $set : { "items.$.product" : "catfood" }})
检查文件-

检查文件-

检查文件-


检查文档-

要更新子文档,需要使用位置运算符


要更新子文档,需要使用“位置”操作符


要更新子文档,需要使用“位置”操作符


要更新子文档,需要使用“位置”操作符

db.lists.update({
    lid: "Qitula",
    items: {$elemMatch: {product: "dogfood"}}
    }, 
    {$set: {"items.$.product": "catfood"}
})