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

$lookup, когато ForeignField е във вложен масив

Не съм сигурен, че разбирам напълно въпроса ви, но това трябва да ви помогне:

db.student.aggregate([{
    $match: { _id: ObjectId("657...") }
}, {
    $lookup: {
        from: 'library',
        localField: '_id' ,
        foreignField: 'issued_to.student',
        as: 'result'
    }
}])

Ако искате да получите само всички book_name s за всеки ученик можете да направите това:

db.student.aggregate([{
    $match: { _id: ObjectId("657657657657657657657657") }
}, {
    $lookup: {
        from: 'library',
        let: { 'stu_id': '$_id' },
        pipeline: [{
            $unwind: '$issued_to' // $expr cannot digest arrays so we need to unwind which hurts performance...
        }, {
            $match: { $expr: { $eq: [ '$issued_to.student', '$$stu_id' ] } }
        }, {
            $project: { _id: 0, "book_name": 1 } // only include the book_name field
        }],
        as: 'result'
    }
}])


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Как да инсталирате MongoDB Community Edition на Ubuntu

  2. Как да експортирате колекция в CSV в MongoDB?

  3. Часовникът Grunt Serve хвърля предупреждение EBUSY върху mongod.lock

  4. MongoDB индексира за $elemMatch

  5. Съхранявайте файл с изображение в двоични данни в схема на mongoose и показвайте изображение в html форма