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

mongodb - rozwijanie zagnieżdżonych poddokumentów

Możesz spróbować poniższej agregacji z mongodb 3.6 i nowszych

List.aggregate([
  { "$match": { "_id": id }},
  { "$lookup": {
    "from": Items.collection.name,
    "let": { "items": "$items" },
    "pipeline": [
      { "$match": { "$expr": { "$in": [ "$_id", "$$items" ] } } }
    ],
    "as": "items"
  }},
  { "$lookup": {
    "from": Lists.collection.name,
    "let": { "included_lists": "$included_lists", "items": "$items" },
    "pipeline": [
      { "$match": { "$expr": { "$in": [ "$_id", "$$included_lists" ] } } },
      { "$lookup": {
        "from": Items.collection.name,
        "let": { "items": "$items" },
        "pipeline": [
          { "$match": { "$expr": { "$in": [ "$_id", "$$items" ] } } }
        ],
        "as": "items"
      }},
      { "$project": { "allItems": { "$concatArrays": [ "$$items", "$items" ]}}}
    ],
    "as": "included_lists"
  }},
  { "$unwind": "$included_lists" },
  { "$replaceRoot": { "newRoot": "$included_lists" }}
])


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Tablica Mongo db zmienia ciąg znaków na pływający

  2. Instalacja MongoDB w Ubuntu 14.04 nie powiodła się

  3. jak pobrać plik zapisany w gridFS za pomocą nodeJS

  4. jak wstawić osadzony dokument za pomocą danych wiosennych mongodb mongotemplate

  5. Szyfruj dane Mongo w Meteorjs