Om meerdere subdocumenten te retourneren, moet u het aggregatieraamwerk gebruiken. Hiermee worden alle subdocumenten geretourneerd waarnaar u op zoek bent:
db.zip.aggregate(
{$match: {zipcode: 63109}},
{$unwind: "$students"},
{$match: {"students.school": 102}}
)
Je kunt verschillende dingen doen om verschillende output te krijgen, maar dit zal terugkeren:
{
"result" : [
{
"_id" : 1,
"zipcode" : 63109,
"students" : {
"name" : "john",
"school" : 102,
"age" : 10
}
},
{
"_id" : 1,
"zipcode" : 63109,
"students" : {
"name" : "jess",
"school" : 102,
"age" : 11
}
},
{
"_id" : 4,
"zipcode" : 63109,
"students" : {
"name" : "barney",
"school" : 102,
"age" : 7
}
}
],
"ok" : 1
}