Имате нужда от допълнителен $match
стъпка на конвейера, която ще филтрира входящите документи въз основа на вграденото поле "$productAttribute.colour"
съществуващ и не нулев:
db.productMetadata.aggregate([
{
"$match": {
"productAttribute.colour": {
"$exists": true,
"$ne": null
}
}
},
{
"$group": {
"_id": {
"color": "$productAttribute.colour",
"gender": "$productAttribute.gender"
},
"count": {
"$sum": 1
}
}
}
]);