Du måste börja med $objectToArray
för att läsa dina nycklar dynamiskt. Sedan kan du $map
egenskaper tillsammans med $anyElementTrue
för att upptäcka om det finns något kapslat fält i thing
som innehåller {"attribute1":"typeC"}
:
db.collection.aggregate([
{
$match: {
$expr: {
$anyElementTrue: {
$map: {
input: { $objectToArray: "$thing" },
in: { $eq: [ "$$this.v.attribute1", "typeC" ] }
}
}
}
}
}
])