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

Dotaz pro převod pole na mapu dokumentů s n atributy

Od MongoDB 3.4.4 a vyšší můžete použít $arrayToObject operátor, který transformuje pole na jeden dokument, a pole by mělo být seznam dokumentů obsahující dvě pole, k a v kde:

Takže byste museli vytvořit kanál, který nejprve transformuje items pole z

"items":[  
    {  
      "id":"AB-02",
      "qty":2
    },
    {  
      "id":"AB-03",
      "qty":0
    },
    {  
      "id":"AB-03",
      "qty":9
    }
]

do

"items" : [ 
    {
        "k" : "AB-02",
        "v" : {
            "id" : "AB-02",
            "qty" : 2.0
        }
    }, 
    {
        "k" : "AB-03",
        "v" : {
            "id" : "AB-03",
            "qty" : 0.0
        }
    }, 
    {
        "k" : "AB-03",
        "v" : {
            "id" : "AB-03",
            "qty" : 9.0
        }
    }
]

$map správně to dělá s výrazem

"$map": {
    "input": "$items",
    "as": "item",
    "in": {
        "k": "$$item.id",
        "v": "$$item"
    }                            
}

Vaše finální potrubí tedy může zabalit všechny výše uvedené operátory do jediné fáze pomocí $addFields jako:

db.collection.aggregate([
    {
        "$addFields": {
            "items": {
                "$arrayToObject": {
                    "$map": {
                        "input": "$items",
                        "as": "item",
                        "in": {
                            "k": "$$item.id",
                            "v": "$$item"
                        }                            
                    }
                }
            }
        }
    }
])



  1. Jak přidám administrátora do Mongo ve verzi 2.6?

  2. Samoodkazované schéma Mongoose nevytváří ObjectId pro všechny dílčí dokumenty

  3. MongoDB extrémně pomalý ve srovnání s MySQL s 10M záznamy

  4. Nelze se připojit k Mongo Atlas pomocí peeringu VPC z clusteru GCP