sql >> Database teknologi >  >> NoSQL >> MongoDB

MongoDB - gruppe sammensat nøgle med indlejrede felter

Du skal først anvende $unwind operator på alle arrays, så du kan lave aggregeringsberegningerne med $group operatør senere i pipeline-stadierne. I sidste ende vil du ende med en aggregeringspipeline som denne:

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
        }
    }
]);

Output

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



  1. Findes der en MongoDB maksimal bson-størrelse?

  2. MongoDB 2.6 Aggregation Framework Forbedringer

  3. Bruger du Redis til at implementere login?

  4. En mere elegant måde at håndtere filtreringsværdier i Angular App