$or - Amazon DocumentDB

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

$or

L'opérateur $or d'agrégation évalue plusieurs expressions et renvoie true si au moins une expression est évaluée à. true Elle false ne renvoie que si toutes les expressions le sontfalse.

Paramètres

  • expressions: tableau d'expressions à évaluer.

Exemple (MongoDB Shell)

L'exemple suivant montre comment utiliser l'$oropérateur pour vérifier si les produits répondent à plusieurs critères.

Création d'exemples de documents

db.items.insertMany([ { _id: 1, name: "Widget", price: 150, onSale: false }, { _id: 2, name: "Gadget", price: 45, onSale: false }, { _id: 3, name: "Tool", price: 200, onSale: true } ]);

Exemple de requête

db.items.aggregate([ { $project: { name: 1, price: 1, onSale: 1, goodDeal: { $or: [ { $lt: ["$price", 50] }, { $eq: ["$onSale", true] } ] } } } ]);

Sortie

[ { _id: 1, name: 'Widget', price: 150, onSale: false, goodDeal: false }, { _id: 2, name: 'Gadget', price: 45, onSale: false, goodDeal: true }, { _id: 3, name: 'Tool', price: 200, onSale: true, goodDeal: true } ]

Exemples de code

Pour afficher un exemple de code relatif à l'utilisation de l'opérateur d'$oragrégation, choisissez l'onglet correspondant à la langue que vous souhaitez utiliser :

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.aggregate([ { $project: { name: 1, price: 1, onSale: 1, goodDeal: { $or: [ { $lt: ["$price", 50] }, { $eq: ["$onSale", true] } ] } } } ]).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.aggregate([ { '$project': { 'name': 1, 'price': 1, 'onSale': 1, 'goodDeal': { '$or': [ { '$lt': ['$price', 50] }, { '$eq': ['$onSale', True] } ] } } } ])) print(result) client.close() example()