выбрать только вложенные документы или массивы - PullRequest
5 голосов
/ 15 февраля 2012
{
    "_id":{
        "oid":"4f33bf69873dbc73a7d21dc3"
    },
    "country":"IND",
    "states":[{
            "name":"orissa",
            "direction":"east",
            "population":41947358,
            "districts":[{
                    "name":"puri",
                    "headquarter":"puri",
                    "population":1498604
                },
                {
                    "name":"khordha",
                    "headquarter":"bhubaneswar",
                    "population":1874405
                }
            ]
        },
        {
            "name":"andhra pradesh",
            "direction":"south",
            "population":84665533,
            "districts":[{
                    "name":"rangareddi",
                    "headquarter":"hyderabad",
                    "population":3506670
                },
                {
                    "name":"vishakhapatnam",
                    "headquarter":"vishakhapatnam",
                    "population":3789823
                }
            ]
        }
    ]
}

В вышеупомянутой коллекции (т.е. странах) у меня есть только один документ, и я хочу получить подробную информацию о конкретном состоянии (скажем, "country.states.name": "orissa"), но я хочу, чтобы мойрезультат как здесь, а не весь документ. Есть способ в Мого ...

     {
    "name": "orissa",
    "direction": "east",
    "population": 41947358,
    "districts": [
        {
            "name": "puri",
            "headquarter": "puri",
            "population": 1498604
        },
        {
            "name": "khordha",
            "headquarter": "bhubaneswar",
            "population": 1874405
        }
    ]
   }

Спасибо

Ответы [ 5 ]

7 голосов
/ 11 марта 2013

Пробовал это:

db.countries.aggregate(      
    {
        "$project": {
            "state": "$states",
            "_id": 0
        }
    },
    {
        "$unwind": "$state"
    },
    {
        "$group": {
            "_id": "$state.name",
            "state": {
                "$first": "$state"
            }
        }
    },
    {
        "$match": {
            "_id": "orissa"
        }
    }
);

И получил:

{
    "result" : [
            {
                    "_id" : "orissa",
                    "state" : {
                            "name" : "orissa",
                            "direction" : "east",
                            "population" : 41947358,
                            "districts" : [
                                    {
                                            "name" : "puri",
                                            "headquarter" : "puri",
                                            "population" : 1498604
                                    },
                                    {
                                            "name" : "khordha",
                                            "headquarter" : "bhubaneswar",
                                            "population" : 1874405
                                    }
                            ]
                    }
            }
    ],
    "ok" : 1
5 голосов
/ 15 февраля 2012

Вы не можете сделать это прямо сейчас, но вы сможете сделать это с помощью $ unwind в инфраструктуре агрегирования . Вы можете попробовать это сейчас с экспериментальной веткой 2.1, стабильная версия выйдет в 2.2, возможно, через несколько месяцев.

2 голосов
/ 15 февраля 2012

Любой запрос в mongodb всегда возвращает корневой документ.

Существует только один способ загрузить один вложенный документ с родителем через $ slice , если известен порядковый номер состояния во вложенном массиве:

// skip ordinalNumberOfState -1, limit 1
db.countries.find({_id: 1}, {states:{$slice: [ordinalNumber -1 , 1]}}) 

$ slice работает в порядке по умолчанию (так как документы были вставлены во вложенный массив). Также, если вам не нужны поля из страны, вы можете включить только _id и указать в результате:

db.countries.find({_id: 1}, {states:{$slice: [ordinalNumber -1 , 1]}, _id: 1}) 

Тогда итоговый документ будет выглядеть так:

{
    "_id":{
        "oid":"4f33bf69873dbc73a7d21dc3"
    },
    "states":[{
            "name":"orissa",
            "direction":"east",
            "population":41947358,
            "districts":[{
                    "name":"puri",
                    "headquarter":"puri",
                    "population":1498604
                },
                {
                    "name":"khordha",
                    "headquarter":"bhubaneswar",
                    "population":1874405
                }
            ]
        }]
}
1 голос
/ 16 февраля 2016
db.countries.find({ "states":  { "$elemMatch": { "name": orissa }}},{"country" : 1, "states.$": 1 })
0 голосов
/ 01 июля 2016

Если вы не хотите использовать aggregate, вы можете сделать это довольно легко на прикладном уровне, используя подчеркивание (включено по умолчанию):

var country = Groops.findOne({"property":value);
var state _.where(country, {"state":statename});

Это даст вам всю запись состояния, которая соответствует statename. Очень удобно.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...