Mongo推送到数组里面的数组

时间:2012-02-09 11:02:15

标签: python mongodb

我是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)

执行时没有错误。但该文件似乎没有变化(没有更新)。我在这做错了什么?

1 个答案:

答案 0 :(得分:2)

由于多种原因,在数组中包含数组几乎总是一个坏主意。我将这些广告系列放在专门的收藏中,以便它们成为顶级文档。

也就是说,您可以通过以下方式推送到特定广告系列的消息数组:

db.members.update(
    {"user_id" : "{1231mjnD-32JIjn-3213}", "campaigns.campaign_id": 3221},
    {$push:{"campaigns.$.messages":{"message_id":4213122, "email":"john@gmail.com"}}}
)