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

$lookup, gdy w zagnieżdżonej tablicy znajduje się obcyField

Nie jestem pewien, czy w pełni rozumiem Twoje pytanie, ale to powinno Ci pomóc:

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

Jeśli chcesz uzyskać tylko wszystkie book_name s dla każdego ucznia możesz to zrobić:

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. Jak agregować i scalać wynik w kolekcję?

  2. Agregacja Mongodb według dnia na podstawie uniksowego znacznika czasu

  3. Dlaczego to polecenie msiexec.exe nie działa w powershell?

  4. Wyciek połączenia Mongo z morfią

  5. Awaria Mongodb otrzymała sygnał 15 (zakończona)