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

Как да обедините данни от две колекции в MongoDB

Тест код тук

Искате $lookup но искате е като SQL като присъединяване, всички полета в основния документ, така че се добавя корен за отвиване и замяна за сливане в 1 документ.

Заявка

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. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Mongodb count срещу findone

  2. Бройте полета в колекция MongoDB

  3. Автоматизация и управление на бази данни с отворен код в облака - обявяване на ClusterControl 1.6

  4. Как да актуализирате стойности с помощта на pymongo?

  5. MongoDB агрегиране PHP, групиране по часове