$or - Amazon DocumentDB

Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.

$or

L'operatore di $or aggregazione valuta più espressioni e restituisce true se almeno un'espressione restituisce lo stesso risultato. true Restituisce false solo se tutte le espressioni lo sono. false

Parametri

  • expressions: Una serie di espressioni da valutare.

Esempio (MongoDB Shell)

L'esempio seguente dimostra l'utilizzo $or dell'operatore per verificare se i prodotti soddisfano uno qualsiasi dei criteri multipli.

Crea documenti di esempio

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 } ]);

Esempio di interrogazione

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

Output

[ { _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 } ]

Esempi di codice

Per visualizzare un esempio di codice per l'utilizzo dell'operatore di $or aggregazione, scegli la scheda relativa alla lingua che desideri utilizzare:

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()