sql >> Databáze >  >> NoSQL >> MongoDB

MongoDB - skupinový složený klíč s vnořenými poli

Nejprve musíte použít $unwind operátor na všech polích, abyste mohli provádět agregační výpočty pomocí $group operátor později ve fázích potrubí. Nakonec skončíte s agregačním kanálem, jako je tento:

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

Výstup

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



  1. Zástupný znak MongoDB v klíči dotazu

  2. Výchozí hodnota není nastavena při použití Update with Upsert jako true

  3. MongoDB Vztah jeden k mnoha

  4. MongoDB diacriticInSensitive vyhledávání nezobrazuje všechny řádky s diakritikou (slova s ​​diakritickým znaménkem) podle očekávání a naopak