Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.
$addToSet
Der $addToSet Aggregationsoperator gibt für jede Gruppe ein Array von Einzelwerten aus einem angegebenen Ausdruck zurück. Er wird innerhalb der $group Phase verwendet, um unterschiedliche Werte zu akkumulieren, wodurch Duplikate automatisch entfernt werden.
Parameter
-
expression: Der Ausdruck, der für jedes Dokument in der Gruppe ausgewertet werden soll.
Beispiel (MongoDB Shell)
Das folgende Beispiel zeigt, wie der $addToSet Operator verwendet wird, um für jeden Kunden eindeutige Städte zu erfassen, in denen Bestellungen aufgegeben wurden.
Erstellen Sie Beispieldokumente
db.orders.insertMany([ { _id: 1, customer: "Alice", city: "Seattle", amount: 100 }, { _id: 2, customer: "Alice", city: "Portland", amount: 150 }, { _id: 3, customer: "Bob", city: "Seattle", amount: 200 }, { _id: 4, customer: "Alice", city: "Seattle", amount: 75 }, { _id: 5, customer: "Bob", city: "Boston", amount: 300 } ]);
Beispiel für eine Abfrage
db.orders.aggregate([ { $group: { _id: "$customer", cities: { $addToSet: "$city" } } } ]);
Ausgabe
[
{ _id: 'Bob', cities: [ 'Seattle', 'Boston' ] },
{ _id: 'Alice', cities: [ 'Seattle', 'Portland' ] }
]
Codebeispiele
Um ein Codebeispiel für die Verwendung des $addToSet Aggregationsoperators anzuzeigen, wählen Sie die Registerkarte für die Sprache, die Sie verwenden möchten: