Aby naśladować funkcjonalność operatora aktualizacji $addToSet z $each modyfikatorem w potoku agregacji, można użyć kombinacji $push na etapie grupowania i $reduce + $setUnion na etapie projekcji. Np.:
db.collection.aggregate([
{$group:{
_id: null,
selectedTags: { $push: '$tags' }
}},
{$project: {
selectedTags: { $reduce: {
input: "$selectedTags",
initialValue: [],
in: {$setUnion : ["$$value", "$$this"]}
}}
}}
])
wyniki z pojedynczym dokumentem, który zawiera odrębną listę tagów ze wszystkich dokumentów w selectedTags
szyk.