Du skal starte med $objectToArray
at læse dine nøgler dynamisk. Så kan du $map
egenskaber sammen med $anyElementTrue
for at opdage, om der er et indlejret felt i thing
indeholdende {"attribute1":"typeC"}
:
db.collection.aggregate([
{
$match: {
$expr: {
$anyElementTrue: {
$map: {
input: { $objectToArray: "$thing" },
in: { $eq: [ "$$this.v.attribute1", "typeC" ] }
}
}
}
}
}
])