这可能吗? 我有一个集合C,具有一系列属性A1。 每个属性都有一个子属性A2的数组。
如何将子文档添加到特定的C.A1子文档?
答案 0 :(得分:8)
这是一个例子。
db.docs.insert({_id: 1, A1: [{A2: [1, 2, 3]}, {A2: [4, 5, 6]}]})
如果您知道要插入的子文档的索引,则可以在中间使用带有索引(从0开始)的点表示法:
db.docs.update({_id: 1}, {$addToSet: {'A1.0.A2': 9}})
这导致:
{
"A1" : [
{
"A2" : [
1,
2,
3,
9
]
},
{
"A2" : [
4,
5,
6
]
}
],
"_id" : 1
}
答案 1 :(得分:0)
是的,这是可能的。如果您发布示例,我可以更具体地向您展示更新查询的外观。但这是一个镜头:
db.c.update({ A1: value }, { $addToSet: { "A1.$.A2": "some value" }})
我实际上没有尝试过这个(我现在不在Mongo实例的前面)并且我要离开记忆,但这应该让你非常接近。
答案 2 :(得分:0)
是的,$ push可以用来做同样的事情。请尝试下面给出的代码。
db.c.update({ A1: value }, { $push: { "A1.$.A2": num }});