$literal - Amazon DocumentDB

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

$literal

Amazon DocumentDB の $literal演算子は、集約パイプラインステージ内のリテラル値を表すために使用されます。これにより、フィールドリファレンスや式として解釈することなく、数値、文字列、ブール値などの特定の値を含めることができます。

この演算子は、動的クエリフィルターの構築や計算の実行など、より複雑な集計パイプラインの一部としてリテラル値を含める必要がある場合に特に便利です。

パラメータ

なし

例 (MongoDB シェル)

次の例は、 $literal演算子を使用してリテラル値を集約パイプラインに含める方法を示しています。$literal 演算子は、値 18 を $gt 式にリテラル値として含めるために使用されます。これにより、集約パイプラインは経過時間フィールドをリテラル値 18 と比較して、その人が成人かどうかを判断できます。

サンプルドキュメントを作成する

db.collection.insertMany([ { "name": "John Doe", "age": 30, "city": "New York" }, { "name": "Jane Doe", "age": 25, "city": "Los Angeles" }, { "name": "Bob Smith", "age": 35, "city": "Chicago" } ]);

クエリの例

db.collection.aggregate([ { $project: { name: 1, age: 1, city: 1, isAdult: { $gt: ["$age", { $literal: 18 }] } } } ]);

出力

[ { "_id": ObjectId("601234567890abcdef012345"), "name": "John Doe", "age": 30, "city": "New York", "isAdult": true }, { "_id": ObjectId("601234567890abcdef012346"), "name": "Jane Doe", "age": 25, "city": "Los Angeles", "isAdult": true }, { "_id": ObjectId("601234567890abcdef012347"), "name": "Bob Smith", "age": 35, "city": "Chicago", "isAdult": true } ]

コードの例

$literal コマンドを使用するコード例を表示するには、使用する言語のタブを選択します。

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('collection'); const result = await collection.aggregate([ { $project: { name: 1, age: 1, city: 1, isAdult: { $gt: ["$age", { $literal: 18 }] } } } ]).toArray(); console.log(result); 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.collection result = list(collection.aggregate([ { '$project': { 'name': 1, 'age': 1, 'city': 1, 'isAdult': { '$gt': ["$age", { '$literal': 18 }] } } } ])) print(result) client.close() example()