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

$nor

Der $nor Operator wird verwendet, um Dokumente abzugleichen, bei denen keine der angegebenen Abfragebedingungen zutrifft. Er ähnelt der logischen Operation „NOR“, bei der das Ergebnis wahr ist, wenn keiner der Operanden wahr ist.

Parameter

  • expression1: Der erste Ausdruck, der ausgewertet werden soll.

  • expression2: Der zweite auszuwertende Ausdruck.

  • expressionN: Zusätzliche auszuwertende Ausdrücke.

Beispiel (MongoDB Shell)

Das folgende Beispiel demonstriert die Verwendung des $nor Operators, indem Dokumente abgerufen werden, bei denen das qty Feld nicht weniger als 20 ist und das size Feld nicht „XL“ entspricht.

Erstellen Sie Beispieldokumente

db.items.insertMany([ { qty: 10, size: "M" }, { qty: 15, size: "XL" }, { qty: 25, size: "L" }, { qty: 30, size: "XL" } ])

Beispiel für eine Abfrage

db.items.find({ $nor: [ { qty: { $lt: 20 } }, { size: "XL" } ] })

Ausgabe

[ { "_id" : ObjectId("..."), "qty" : 25, "size" : "L" } ]

Codebeispiele

Um ein Codebeispiel für die Verwendung des $nor 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('items'); const result = await collection.find({ $nor: [ { qty: { $lt: 20 } }, { size: "XL" } ] }).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['items'] result = list(collection.find({ '$nor': [ { 'qty': { '$lt': 20 } }, { 'size': 'XL' } ] })) print(result) client.close() example()