$or - Amazon DocumentDB

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

$or

$or聚合运算符计算多个表达式,true如果至少有一个表达式的计算结果为,则返回。truefalse仅当所有表达式均为时,它才会返回false

参数

  • expressions:要计算的表达式数组。

示例(MongoDB 外壳)

以下示例演示如何使用$or运算符来检查产品是否符合多个条件中的任何一个。

创建示例文档

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

查询示例

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

输出

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

代码示例

要查看使用$or聚合运算符的代码示例,请选择要使用的语言的选项卡:

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