sql >> Database >  >> NoSQL >> MongoDB

$lookup wanneer ForeignField in geneste array staat

Ik weet niet zeker of ik je vraag helemaal begrijp, maar dit zou je moeten helpen:

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

Als je alleen de hele book_name . wilt krijgen s voor elke leerling kun je dit doen:

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. Java MongoDB POST:415 niet-ondersteund mediatype

  2. Sorteer een geneste array in mangoest

  3. Hoe vul je een-op-veel-relatie in mangoest met ouderreferentie?

  4. Rails en caching, is het makkelijk om te wisselen tussen memcache en redis?