$setIntersection - Amazon DocumentDB

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.

$setIntersection

Der $setIntersection Operator in Amazon DocumentDB wird verwendet, um die gemeinsamen Elemente zwischen zwei oder mehr Arrays zurückzugeben. Dieser Operator ist besonders nützlich, wenn Sie mit Datensätzen arbeiten. Er ermöglicht es Ihnen, die Schnittmenge mehrerer Datensätze zu ermitteln.

Parameter

  • array1: Das erste Array, das sich überschneidet.

  • array2: Das zweite Array, das sich überschneiden soll.

  • arrayN: (optional) Zusätzliche Arrays, die sich überschneiden sollen.

Beispiel (MongoDB Shell)

Das folgende Beispiel zeigt, wie der $setIntersection Operator verwendet wird, um die gemeinsamen Elemente zwischen zwei Arrays zu finden.

Erstellen Sie Beispieldokumente

db.collection.insertMany([ { _id: 1, colors: ["red", "blue", "green"] }, { _id: 2, colors: ["blue", "yellow", "orange"] }, { _id: 3, colors: ["red", "green", "purple"] } ])

Beispiel für eine Abfrage

db.collection.aggregate([ { $project: { _id: 1, commonColors: { $setIntersection: ["$colors", ["red", "blue", "green"]] } } } ])

Ausgabe

[ { "_id": 1, "commonColors": ["red", "blue", "green"] }, { "_id": 2, "commonColors": ["blue"] }, { "_id": 3, "commonColors": ["red", "green"] } ]

Codebeispiele

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

Node.js
const { MongoClient } = require('mongodb'); async function example() { 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'); const result = await collection.aggregate([ { $project: { _id: 1, commonColors: { $setIntersection: ["$colors", ["red", "blue", "green"]] } } } ]).toArray(); console.log(result); client.close(); } example();
Python
from pymongo import MongoClient def example(): 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'] result = list(collection.aggregate([ { '$project': { '_id': 1, 'commonColors': { '$setIntersection': ["$colors", ["red", "blue", "green"]] } } } ])) print(result) client.close() example()