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

Jak sloučit data ze dvou kolekcí v MongoDB

Testovací kód zde

Chcete $lookup ale vy chcete je jako SQL jako join, všechna pole v kořenovém dokumentu, takže kořenový adresář pro rozbalení a nahrazení je přidán ke sloučení do 1 dokumentu.

Dotaz

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. jak převést pole na objekt v MongoDB

  2. Redis with Resque a Rails:Příkaz ERR není povolen při použití paměti> 'maxmemory'

  3. Nelze upgradovat sharded mongoDB nebo zastavit balancer

  4. Efekt generování mongodb _id na indexování