mongodb находит документ по id, а затем группирует результат на основе поля имени - PullRequest
0 голосов
/ 28 апреля 2018

У меня есть коллекция с несколькими документами, такими как

{
    "_id" : ObjectId("5a64d076bfd103df081967ae"),
    "status" : "",
    "Number" : 53,
    "values" : [ 
        {
            "date" : "2015-05-18",
            "value" : 12.41
        },
        {
            "date" : "2015-05-19",
            "value" : 12.45
        },

    ],
    "Name" : "ABC Banking",
    "scheme":"ABC1",
    "createdDate" : "21-01-2018"
}

{
    "_id" : ObjectId("5a64d076bfd103df081967ae"),
    "status" : "",
    "Number" : 53,
    "values" : [ 
        {
            "date" : "2015-05-18",
            "value" : 13.41
        },
        {
            "date" : "2015-05-19",
            "value" : 13.45
        },

    ],
    "Name" : "ABC Banking",
    "scheme":"ABC2",
    "createdDate" : "21-01-2018"
}

Я запрашиваю коллекцию на основе поля Number, например

db.getCollection('mfhistories').find({'Number':53})

чтобы получить все документы с этим номером.

Теперь я хочу сгруппировать всю коллекцию с именем «ABC Banking» в массив. так что я получу результат на основе имени.

так что результат должен быть как

{        
   "Name":"ABC Banking",
   [
     {
        "_id" : ObjectId("5a64d076bfd103df081967ae"),
        "status" : "",
        "Number" : 53,
        "values" : [ 
            {
                "date" : "2015-05-18",
                "value" : 13.41
            },
           {
               "date" : "2015-05-19",
               "value" : 13.45
           }, 
        ],
            "scheme":"ABC1",
            "createdDate" : "21-01-2018"
       },
       {
            "_id" : ObjectId("5a64d076bfd103df081967ae"),
            "status" : "",
            "Number" : 53,
            "values" : [ 
            {
               "date" : "2015-05-18",
               "value" : 13.41
            },
            {
               "date" : "2015-05-19",
               "value" : 13.45
            }
           ], 
          "scheme":"ABC2",
           "createdDate" : "21-01-2018"
         }
    ]
}

Пожалуйста, помогите ..

Спасибо, J

Ответы [ 2 ]

0 голосов
/ 02 мая 2018
db.mfhistories.aggregate(

    // Pipeline
    [
        // Stage 1
        {
            $match: {
                Number: 53
            }
        },

        // Stage 2
        {
            $group: {
                _id: {
                    Name: '$Name'
                },
                docObj: {
                    $addToSet: '$$CURRENT'
                }
            }
        },

        // Stage 3
        {
            $project: {
                Name: '$_id.Name',
                docObj: 1,
                _id: 0
            }
        }

    ]


);
0 голосов
/ 28 апреля 2018

Для этого можно использовать Aggregation Framework:

db.col.aggregate([
    {
        $match: { Number: 53, Name: "ABC Banking" }
    },
    {
        $group: {
            _id: "$Name",
            docs: { $push: "$$ROOT" }
        }
    },
    {
        $project: {
            Name: "$_id",
            _id: 0,
            docs: 1
        }
    }
])

$$ROOT - это специальная переменная, которая захватывает весь документ. Подробнее здесь .

...