mongodb upsert更新数组元素

时间:2013-10-02 12:01:05

标签: mongodb

想要在文档数组中的对象属性中插入

考虑集合m

中的文档
{ "_id" : ObjectId("524bfc39e6bed5cc5a9f3a33"), 
 "x" : [       
    { "id":0.0, "name":"aaa"},{ "id":1.0, "name":"bbb"}  
 ]
}

想要age:100添加到{ "id":0.0, "name":"aaa"}。 不仅仅是年龄..但是在数组元素{}中提供upsert。所以它可以包含{age:100,"city":"amd"}(因为我从应用程序服务获得这个)

正在尝试这个......但没有奏效,因为它取代了整个数组元素

db.m.update({_id:ObjectId("524bfc39e6bed5cc5a9f3a33"),
     "x" : {
                "$elemMatch" : {
                        "id" : 0.0
                }
}},
{
        $set : {
                "x.$" : {
                    "age": 100
            }
        }
},
{upsert: true}
)

将文档更改为(我不想要的)

 { "_id" : ObjectId("524bfc39e6bed5cc5a9f3a33"), 
     "x" : [       
        { "age":100},{ "id":1.0, "name":"bbb"}  
     ]
    }

这是否可以在不改变架构的情况下实现。

2 个答案:

答案 0 :(得分:6)

$set : {"x.$" : {"age": 100}}

x.$将整个匹配的数组元素设置为{age: 100}

这应该有效:

db.m.update({_id:ObjectId("524bfc39e6bed5cc5a9f3a33"),
"x.id": 0.0}, {$set: {"x.$.age": 100 }});

使用elemMatch

db.test.update({x: {$elemMatch: {id: 1}}},{$set:  {"x.$.age": 44}})

请注意,此处的upsert选项是多余的,如果id中不存在x,则无效,因为位置运算符$不会支持upserting

答案 1 :(得分:0)

如果不更改架构,这是不可能的。如果您可以更改架构以使用对象来存储项目(而不是数组),则可以按照我在this answer中概述的方法进行操作。