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

Kueri agregat MongoDb bergabung dengan dua koleksi

anda hanya perlu mendeklarasikan $someField di bagian biarkan.

db.collectionA.aggregate([
  {
    $lookup: {
      from: 'collectionB',
      let: { some_field: '$someField' },
      pipeline: [
        { $match: {
            $expr: {
              $and: [
                { $eq: [ "$someField", "$$some_field" ] },
                { $eq: [ "$otherField", "789" ] }
              ]
            }
          }
        }
      ],
      as: 'B'
    }
  },
  {
    $match: {
      $expr: {
        $gt: [ { $size: "$B" }, 0 ]
      }
    }
  }
])

https://mongoplayground.net/p/RTiUMWl8QaX



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. 2 Cara Membatasi Dokumen yang Dikembalikan di MongoDB

  2. Menemukan Dokumen Tersemat oleh properti tertentu di Mongoose, Node.js, MongodDB

  3. Mongodb $push dalam array bersarang

  4. Fungsi Mongodb findOneAndUpdate sedang memasukkan dokumen baru

  5. Panggilan luwak ke geoNear dengan poin GeoJSON karena parameter kueri tidak berfungsi