Можете да използвате $objectToArray
(mongoDB 3.4.4 и по-нова), $filter и $project
и да получите нещо като това:
db.collection.aggregate([
{
$project: {
obj: {
$objectToArray: "$info"
}
}
},
{
$project: {
_id: 0,
obj: {
$filter: {
input: "$obj",
as: "item",
cond: {
$eq: [
"$$item.v.city",
"NY"
]
}
}
}
}
},
{
$project: {
info: {
$arrayToObject: "$obj"
}
}
},
])
Можете да го видите работещ тук
Идеята е да разделите обекта на масив, да го филтрирате и след това да преобразувате този масив обратно в обект.
Филтрирах по city
но съм сигурен, че разбирате идеята.