sql >> Databasteknik >  >> NoSQL >> MongoDB

Totala värden från alla nycklar i underdokument

Det finns inget sätt i mongodb-aggregationsramverket för att behandla en nyckel inuti ett dokument som data du kan granska eller manipulera. En lösning är att omvandla det du använder som nycklar här (t.ex. frukttyp och butiksnamn) till värden som detta:

{
    "_id" : "doc1",
    "stores":[
        {
            // store name is a value
            "name":"store_A",
            "inventory": [
            {
                // so is fruit type
                "type" : "apple",
                "count" : 50
            },
            {
                "type" : "orange",
                "count" : 20
            }
            ]
        },
        {
            "name": "store_B",
            "inventory": [
            {
                "type" : "orange",
                "count" : 15
            }
            ]
        }
    ]
}

Detta gör att du lättare kan arbeta med dessa data i aggregering:

db.coll.aggregate([
    // split documents by store name
    {$unwind:"$stores"},
    // split documents further by fruit type
    {$unwind:"$stores.inventory"},
    // group documents together by store/fruit type, count quantities of fruit
    {$group:{"_id":{"store":"$stores.name", "fruit":"$stores.inventory.type"},
             "count":{$sum:"$stores.inventory.count"}}},
    // reformat the data to look more like your specification
    {$project:{
        "store":"$_id.store",
        "fruit":"$_id.fruit",
        "_id":0,
        "count":1}}])

Utdatan ser ut så här:

{
    "result" : [
        {
            "count" : 15,
            "store" : "store_B",
            "fruit" : "apple"
        },
        {
            "count" : 15,
            "store" : "store_B",
            "fruit" : "orange"
        },
        {
            "count" : 30,
            "store" : "store_A",
            "fruit" : "orange"
        },
        {
            "count" : 50,
            "store" : "store_A",
            "fruit" : "apple"
        }
    ],
    "ok" : 1
}



  1. Indexering av parallella arrayer i Mongodb

  2. Mongoose QueryStream nya resultat

  3. Topp 10 funktioner i MongoDB Atlas

  4. Vad är en bra strategi för att gruppera liknande ord?