想要在文档数组中的对象属性中插入
考虑集合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"}
]
}
这是否可以在不改变架构的情况下实现。
答案 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中概述的方法进行操作。