如何从mongoDB集合中获取数组?

我在mongoDB中有这样的模式

{
    "key":"ru",
    "regions":[
        {
            "name":"moskovskaya",
            "cities":[
                {
                    "name":"moskva"
                },
                {
                    "name":"tula"
                }
            ]
        },
        {
            "name":"piterskaya",
            "cities":[
                {
                    "name":"piter"
                },
                {
                    "name":"luga"
                }
            ]
        }
    ]
}

我有一些针对不同国家的这种模式的文件,
如何从此架构的每个文档中获取所有城市的数组?

运行以下聚合管道:

db.collection.aggregate([
    { "$unwind": "$regions" },
    { "$unwind": "$regions.cities" },
    {
        "$group": {
            "_id": null,
            "cities": { "$push": "$regions.cities.name" }
        }
    }
])

样本输出

{
    "result" : [ 
        {
            "_id" : null,
            "cities" : [ 
                "moskva", 
                "tula", 
                "piter", 
                "luga"
            ]
        }
    ],
    "ok" : 1
}
https://stackoverflow.com/questions/38210121/how-to-get-array-from-mongodb-collection

本站文章除注明转载外,均为本站原创或编译
转载请明显位置注明出处:如何从mongoDB集合中获取数组?