MongoDB
 sql >> Teknologi Basis Data >  >> NoSQL >> MongoDB

Cara menggabungkan data dari dua koleksi di MongoDB

Uji kode di sini

Anda ingin $lookup tetapi yang Anda inginkan adalah seperti SQL seperti join, semua bidang di dokumen root sehingga melepas dan mengganti root ditambahkan untuk digabungkan dalam 1 dokumen.

Kueri

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 tidak dapat mengurai kueri (2dsphere):dua kondisi

  2. Gunakan mongoexport dengan --query untuk ISODate

  3. MongoRepository @Query Gagal mengurai string sebagai tanggal

  4. Cara mendapatkan kembali dokumen Asli setelah agregasi

  5. Pertanyaan Terikat MongoDB:Bagaimana cara mengonversi mil ke radian?