$in - 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.

$in

Der $in Aggregationsoperator prüft, ob ein bestimmter Wert innerhalb eines Arrays existiert. Er gibt zurücktrue, ob der Wert im Array gefunden wurde, und false andernfalls.

Parameter

  • value: Der Wert, nach dem gesucht werden soll.

  • array: Das Array, in dem gesucht werden soll.

Beispiel (MongoDB Shell)

Das folgende Beispiel zeigt, wie der $in Operator verwendet wird, um zu überprüfen, ob in den Fähigkeiten jedes Mitarbeiters eine bestimmte Fähigkeit vorhanden ist.

Erstellen Sie Beispieldokumente

db.employees.insertMany([ { _id: 1, name: "Sarah", skills: ["Python", "JavaScript", "SQL"] }, { _id: 2, name: "Mike", skills: ["Java", "C++", "Go"] }, { _id: 3, name: "Emma", skills: ["Python", "Ruby", "Rust"] } ]);

Beispiel für eine Abfrage

db.employees.aggregate([ { $project: { name: 1, hasPython: { $in: ["Python", "$skills"] } } } ]);

Ausgabe

[ { _id: 1, name: 'Sarah', hasPython: true }, { _id: 2, name: 'Mike', hasPython: false }, { _id: 3, name: 'Emma', hasPython: true } ]

Codebeispiele

Um ein Codebeispiel für die Verwendung des $in Aggregationsoperators 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('employees'); const result = await collection.aggregate([ { $project: { name: 1, hasPython: { $in: ["Python", "$skills"] } } } ]).toArray(); console.log(result); await 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['employees'] result = list(collection.aggregate([ { '$project': { 'name': 1, 'hasPython': { '$in': ['Python', '$skills'] } } } ])) print(result) client.close() example()