MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Zapytanie Agregat MongoDb łączy dwie kolekcje

wystarczy zadeklarować $someField w sekcji let.

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. Mongoose this.model nie jest funkcją

  2. Utwórz wykres d3.js z danych na serwerze mongodb

  3. Jak zaktualizować wszystkie dokumenty w mongodb PHP?

  4. Indeksowanie Mongo na tablicach obiektów a obiekty

  5. nie mogę wykonać wezwania na odpoczynek