

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.

# \$1setDifference
<a name="setDifference"></a>

Neu ab Version 4.0.

Der `$setDifference` Operator in Amazon DocumentDB wird verwendet, um zwei Sätze zu vergleichen und die Elemente zurückzugeben, die sich in der ersten Gruppe, aber nicht in der zweiten Gruppe befinden. Dieser Operator ist nützlich, um die eindeutigen Elemente zwischen zwei Sätzen zu finden.

**Parameter**
+ `firstSet`: Der erste Satz, der verglichen werden soll.
+ `secondSet`: Der zweite zu vergleichende Satz.

## Beispiel (MongoDB Shell)
<a name="setDifference-examples"></a>

Das folgende Beispiel zeigt, wie der `$setDifference` Operator verwendet wird, um die eindeutigen Elemente zwischen zwei Sätzen zu finden.

**Erstellen Sie Beispieldokumente**

```
db.collection.insertMany([
  { _id: 1, fruits: ["apple", "banana", "cherry", "date"] },
  { _id: 2, fruits: ["banana", "cherry", "date", "elderberry"] }
]);
```

**Beispiel für eine Abfrage**

```
db.collection.aggregate([
  {
    $project: {
      uniqueFruits: { $setDifference: ["$fruits", ["banana", "cherry", "date"]] }
    }
  }
]);
```

**Ausgabe**

```
[
  { "_id": 1, "uniqueFruits": ["apple"] },
  { "_id": 2, "uniqueFruits": ["elderberry"] }
]
```

Die Abfrage führt die folgenden Schritte aus:

1. Sie verwendet die `$project` Phase, um `uniqueFruits` für jedes Dokument ein neues Feld zu erstellen.

2. Der `$setDifference` Operator vergleicht das `fruits` Array mit dem Array `[&quot;banana&quot;, &quot;cherry&quot;, &quot;date&quot;]` und gibt die eindeutigen Elemente im `fruits` Array zurück.

## Codebeispiele
<a name="setDifference-code"></a>

Um ein Codebeispiel für die Verwendung des `$setDifference` Befehls anzuzeigen, wählen Sie die Registerkarte für die Sprache, die Sie verwenden möchten:

------
#### [ Node.js ]

Hier ist ein Beispiel für die Verwendung des `$setDifference` Operators in einer Node.js -Anwendung:

```
const { MongoClient } = require('mongodb');

async function main() {
  const client = await MongoClient.connect('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false');
  const db = client.db('test');
  const collection = db.collection('mycollection');

  // Insert sample documents
  await collection.insertMany([
    { _id: 1, fruits: ["apple", "banana", "cherry", "date"] },
    { _id: 2, fruits: ["banana", "cherry", "date", "elderberry"] }
  ]);

 // Query using $setDifference
  const result = await collection.aggregate([
    {
      $project: {
        uniqueFruits: { $setDifference: ["$fruits", ["banana", "cherry", "date"]] }
      }
    }
  ]).toArray();

  console.log(result);
  await client.close();
}

main();
```

------
#### [ Python ]

Hier ist ein Beispiel für die Verwendung des `$setDifference` Operators in einer Python-Anwendung:

```
from pymongo import MongoClient

def main():
    client = MongoClient('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false')
    db = client['test']
    collection = db['mycollection']

    # Insert sample documents
    collection.insert_many([
        {'_id': 1, 'fruits': ["apple", "banana", "cherry", "date"]},
        {'_id': 2, 'fruits': ["banana", "cherry", "date", "elderberry"]}
    ])

    # Query using $setDifference
    result = list(collection.aggregate([
        {
            '$project': {
                'uniqueFruits': {'$setDifference': ['$fruits', ["banana", "cherry", "date"]]}
            }
        }
    ]))

    print(result)
    client.close()

if __name__ == '__main__':
    main()
```

------