$expr - Amazon DocumentDB

As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.

$expr

Novo a partir da versão 4.0.

Não é compatível com o cluster elástico.

O $expr operador no Amazon DocumentDB permite que você use expressões de agregação dentro da linguagem de consulta. Ele permite que você realize comparações e cálculos complexos em campos em um documento, da mesma forma que você usaria os estágios do pipeline de agregação.

Parâmetros

  • expression: uma expressão que retorna um valor booleano, permitindo que você realize comparações e cálculos nos campos do documento.

Exemplo (MongoDB Shell)

O exemplo a seguir demonstra como usar o $expr operador para encontrar todos os documentos em que o manufacturingCost campo é maior que o price campo.

Crie documentos de amostra

db.inventory.insertMany([ { item: "abc", manufacturingCost: 500, price: 100 }, { item: "def", manufacturingCost: 300, price: 450 }, { item: "ghi", manufacturingCost: 400, price: 120 } ]);

Exemplo de consulta

db.inventory.find({ $expr: { $gt: ["$manufacturingCost", "$price"] } })

Saída

{ "_id" : ObjectId("60b9d4d68d2cac581bc5a89a"), "item" : "abc", "manufacturingCost" : 500, "price" : 100 }, { "_id" : ObjectId("60b9d4d68d2cac581bc5a89c"), "item" : "ghi", "manufacturingCost" : 400, "price" : 120 }

Exemplos de código

Para ver um exemplo de código para usar o $expr comando, escolha a guia do idioma que você deseja usar:

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('inventory'); const result = await collection.find({ $expr: { $gt: ['$manufacturingCost', '$price'] } }).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['inventory'] result = list(collection.find({ '$expr': { '$gt': ['$manufacturingCost', '$price'] } })) print(result) client.close() example()