MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

MongoDB - grupowy klucz złożony z zagnieżdżonymi polami

Najpierw musisz zastosować $unwind operator we wszystkich tablicach, dzięki czemu można wykonać obliczenia agregacji za pomocą $group operatora na późniejszych etapach rurociągu. W końcu otrzymasz taki potok agregacji:

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

Wyjście

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



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Obsługa rozłączeń/ponownych połączeń MongoDB z węzła

  2. ClusterControl — wszystkie najważniejsze funkcje i ulepszenia z 2017 roku

  3. Mongoid - limit odrębnych zapytań

  4. Wskazówki dotyczące zarządzania konfiguracjami baz danych

  5. Wyszukiwanie wszystkich rekordów zawierających dane podpole w mongodb