För att efterlikna funktionen hos $addToSet-uppdateringsoperatören med $each modifier i aggregeringspipeline kan du använda en kombination av $push på grupperingsstadiet och $reduce + $setUnion på projektionsstadiet. T.ex.:
db.collection.aggregate([
{$group:{
_id: null,
selectedTags: { $push: '$tags' }
}},
{$project: {
selectedTags: { $reduce: {
input: "$selectedTags",
initialValue: [],
in: {$setUnion : ["$$value", "$$this"]}
}}
}}
])
resultat med ett enda dokument som innehåller en distinkt lista med taggar från alla dokument i selectedTags
array.