$elemmatch(zapytanie) zwraca wszystkie wiersze w tablicy, gdy przynajmniej jeden wiersz pasuje do kryteriów zapytania.
$elemMatch(projekcja) zwraca tylko pierwszy wiersz ze wszystkich pasujących wierszy, gdy jest używany jako projekcja.
Możesz łatwo uzyskać wszystkie pasujące wiersze, używając operatora agregacji tablic $filtr .
W tym scenariuszu szczegóły produktu będą filtrowane na podstawie przekazanych kryteriów.
aggregate([{
$match: {
"project_code": 'usha-fos'
}
}, {
$project: {
"agency_code": 1,
"client_code": 1,
"project_code": 1,
"product_details": {
"$filter": {
"input": "$product_details",
"as": "result",
cond: {
$eq: ["$$result.Division", "Electric Fans"]
}
}
}
}
}])