sql >> Databáze >  >> NoSQL >> MongoDB

$lookup, když je ForeignField ve vnořeném poli

Nejsem si jistý, zda zcela rozumím vaší otázce, ale mělo by vám pomoci:

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

Pokud chcete získat pouze všechny book_name s pro každého studenta můžete provést toto:

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. Náhodný výběr z Mongo

  2. stránkování pole mongoDB

  3. Problém s analýzou serveru a mongodb

  4. Rozdíl mezi ukládáním celých čísel a řetězců v Redis