sql >> Databasteknik >  >> NoSQL >> MongoDB

Hur man slår samman data från två samlingar i MongoDB

Testkod här

Du vill ha en $lookup men du vill är som SQL som join, alla fält i rotdokumentet så att en varva ner och ersätta root läggs till för att slå samman i ett dokument.

Fråga

db.user_relations.aggregate([
  {
    "$match": {
      "$expr": {
        "$eq": [
          "$userId",
          "userId1"
        ]
      }
    }
  },
  {
    "$unwind": {
      "path": "$friendsArray"
    }
  },
  {
    "$sort": {
      "friendsArray.lastTimeStamp": 1
    }
  },
  {
    "$limit": 10
  },
  {
    "$replaceRoot": {
      "newRoot": "$friendsArray"
    }
  },
  {
    "$lookup": {
      "from": "users",
      "localField": "userId",
      "foreignField": "_id",
      "as": "joined__"
    }
  },
  {
    "$unwind": {
      "path": "$joined__"
    }
  },
  {
    "$replaceRoot": {
      "newRoot": {
        "$mergeObjects": [
          "$joined__",
          "$$ROOT"
        ]
      }
    }
  },
  {
    "$project": {
      "joined__": 0
    }
  }
])



  1. Apache Phoenix för CDH

  2. Översättning av sql-fråga till Mongo språk

  3. MongoDb Select Query Issue Whit Regular Expression (börjar med och slutar med)

  4. Spring Data MongoDB 4.0 transaktionsstöd