我是mongo的新手,到目前为止使用它没有任何问题。直到我坚持这一点。我需要将文档推送到数组内的数组。可以参考下面的json。
{
'user_id':'{1231mjnD-32JIjn-3213}',
'name':'John',
'campaigns':
[
{
'campaign_id':3221,
'start_date':'12-01-2012',
'messages':
[
{
'message_id':211134,
'email':'john@gmail.com'
}
]
},
{
'campaign_id':3222,
'start_date':'13-01-2012',
'messages':
[
{
'message_id':315521,
'email':'john@gmail.com'
}
]
}
]
}
我想将一个文档推送到广告系列数组中的一系列消息(无论是否订购)。这意味着,我需要将新文档附加到一组消息中。所有这些消息都来自另一个阵列或每个用户的广告系列。我使用python所以我的代码将是这样的。
query = {"user_id" : "{1231mjnD-32JIjn-3213}", "campaigns.campaign_id": 3221}
message = {"message_id":4213122, "email":"john@gmail.com"}
op = {"$push" : {"campaigns.messages":message}}
mongo.TestDatabase.members.update(query, op)
执行时没有错误。但该文件似乎没有变化(没有更新)。我在这做错了什么?
答案 0 :(得分:2)
由于多种原因,在数组中包含数组几乎总是一个坏主意。我将这些广告系列放在专门的收藏中,以便它们成为顶级文档。
也就是说,您可以通过以下方式推送到特定广告系列的消息数组:
db.members.update(
{"user_id" : "{1231mjnD-32JIjn-3213}", "campaigns.campaign_id": 3221},
{$push:{"campaigns.$.messages":{"message_id":4213122, "email":"john@gmail.com"}}}
)