MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Заявка за преобразуване на масив в карта на документи с n атрибута

От MongoDB 3.4.4 и по-нови можете да използвате $arrayToObject оператор, който трансформира масив в един документ и масивът трябва да бъде списък от документи, който съдържа две полета, k и v където:

Така че ще трябва да създадете конвейер, който първо трансформира items масив от

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

до

"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 правилно прави това с израза

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

Така че окончателният ви конвейер може да обвие всички горни оператори в един етап с $addFields като:

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



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Документ Прочетете и вмъкнете със заключване/транзакция в nodejs с mongodb

  2. Как да използвате функцията за агрегиране mongo db-query

  3. MongoDB регистрира всички заявки

  4. Едновременна актуализация на елементи от масив, които са вградени документи в MongoDB

  5. Можете ли да използвате заявки за намиране на GridFS с помощта на API на javascript?