sql >> Databasteknik >  >> NoSQL >> MongoDB

MongoDB - grupp sammansatt nyckel med kapslade fält

Du måste först tillämpa $unwind operatorn på alla arrayer så att du kan göra aggregeringsberäkningarna med $group operatör senare i pipelineskedet. I slutändan kommer du att få en aggregeringspipeline så här:

db.testing.aggregate([
    { "$unwind": "$Event_types" },
    { "$unwind": "$Event_types.events" },
    { "$unwind": "$Event_types.events.by" },
    { "$unwind": "$Event_types.events.by.countArray" },
    {
        "$group": {
            "_id": {
                "type": "$Event_types.type",
                "name": "$Event_types.events.eventName",
                "siteName": "$Event_types.events.by.siteName"
            },
            "total": { 
                "$sum": "$Event_types.events.by.countArray.value"
            }
        }
    },
    {
        "$project": {
            "_id": 0,
            "type": "$_id.type",
            "name": "$_id.name",
            "siteName": "$_id.siteName",
            "total": 1
        }
    }
]);

Utdata

/* 1 */
{
    "result" : [ 
        {
            "total" : 90,
            "type" : "Party",
            "name" : "After Party",
            "siteName" : "PostParty"
        }, 
        {
            "total" : 40,
            "type" : "Party",
            "name" : "After Party",
            "siteName" : "club8"
        }
    ],
    "ok" : 1
}



  1. Fråga efter data från MongoDB med GraphQL i Django:Get-Go (1)

  2. NodeJS + Mongo native – kontrollera om samlingen finns före fråga

  3. Hur man jämför 2 fält i Spring Data MongoDB med hjälp av frågeobjekt

  4. välj distinkt mongodb C#