$in в заявката за търсене е проектирана да връща документи, а не поддокументи. Във вашия случай mongoDB е предоставил рамката за агрегиране. Това ще ви помогне да филтрирате поддокументи.
За mongoDB <=3.0.x
db.collection.aggregate(
{ $project: { Brand: 1}},
{ $unwind: '$Brand'},
{ $match: { "Brand.name" : { $in : ["Reebok", "Adidas"]}}},
{ $group: { _id: '$_id', Brand: {$push : '$Brand' }}}
)
MongoDB 3.2 начин
db.collection.aggregate([
{
$project: {
Brand: {
$filter: {
input: "$Brand",
as: "Brand",
cond: { "$$Brand.name": { $in : ["Reebok", "Adidas"]}}
}
}
}
}
])