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

Wyszukaj i posortuj kolekcję zagraniczną

Nie musisz $unwind treningi tablica, ponieważ zawiera już tablicę _id s i użyj $replaceRoot zamiast robić $project

Users.aggregate([
  { "$match": { "_id" : ObjectId("whateverTheUserIdIs") }}, 
  { "$lookup": {
    "from" : "workouts", 
    "localField" : "workouts", 
    "foreignField" : "_id", 
    "as" : "workoutDocumentsArray"
  }},
  { "$unwind": "$workoutDocumentsArray" },
  { "$replaceRoot": { "newRoot": "$workoutDocumentsArray" }}
  { "$sort" : { "date" : -1 }}
])

lub nawet z nowym $wyszukaj składnia

Users.aggregate([
  { "$match" : { "_id": ObjectId("whateverTheUserIdIs") }}, 
  { "$lookup" : {
    "from" : "workouts", 
    "let": { "workouts": "$workouts" },
    "pipeline": [
      { "$match": { "$expr": { "$in": ["$_id", "$$workouts"] }}},
      { "$sort" : { "date" : -1 }}
    ]
    "as" : "workoutDocumentsArray"
  }},
  { "$unwind": "$workoutDocumentsArray" },
  { "$replaceRoot": { "newRoot": "$workoutDocumentsArray" }}
])



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Agregacja Mongo i MongoError:wyjątek:BufBuilder próbował zwiększyć() do 134217728 bajtów, przekraczając limit 64 MB

  2. Jak usunąć właściwość zagnieżdżonego obiektu z dokumentu MongoDB?

  3. środowisko wykonawcze korzystania z indeksowania w mongodb

  4. Jak porównać 2 pola w Spring Data MongoDB za pomocą obiektu zapytania

  5. Samouczek MongoDB dla początkujących (kompletny przewodnik) – Naucz się MongoDB w 15 minut