Możesz $unwind Twoja tablica, aby pobrać pojedynczy dokument na element, a następnie uruchom $group aby policzyć elementy:
db.collection.aggregate([
{
$unwind: "$elements"
},
{
$group: {
_id: "$elements",
count: { $sum: 1 }
}
}
])
EDYCJA:możesz użyć dodatkowej grupy z $replaceRoot i $arrayToObject aby zwrócić identyfikatory jako klucze i zliczać jako wartości:
db.collection.aggregate([
{
$unwind: "$elements"
},
{
$group: {
_id: "$elements",
count: { $sum: 1 }
}
},
{
$group: {
_id: null,
counts: { $push: { k: "$_id", v: "$count" } }
}
},
{
$replaceRoot: {
newRoot: { $arrayToObject: "$counts" }
}
}
])