$setIsSubset - Amazon DocumentDB

本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。

$setIsSubset

Amazon DocumentDB 中的$setIsSubset運算子用於判斷一組值是否為另一個集合的子集。它適用於在陣列欄位上執行以集合為基礎的比較和操作。

參數

  • field:要套用$setIsSubset運算子的欄位。

  • set:要比較欄位的集合。

範例 (MongoDB Shell)

下列範例示範 $setIsSubset運算子的使用情況,以檢查 tags 欄位是否為指定集的子集。

建立範例文件

db.products.insertMany([ { _id: 1, name: "Product A", tags: ["tag1", "tag2", "tag3"] }, { _id: 2, name: "Product B", tags: ["tag1", "tag2"] }, { _id: 3, name: "Product C", tags: ["tag2", "tag3"] } ]);

查詢範例

db.products.find({ $expr: { $setIsSubset: [["tag1", "tag2"], "$tags"] } })

*注意:* $setIsSubset是彙總運算子,無法直接用於 find() 查詢。在此範例中, $expr 與 搭配使用,find()以橋接查詢運算子和彙總表達式之間的間隙。

輸出

[ { "_id" : 1, "name" : "Product A", "tags" : [ "tag1", "tag2", "tag3" ] }, { "_id" : 2, "name" : "Product B", "tags" : [ "tag1", "tag2" ] } ]

查詢會傳回 tags 欄位是集合 子集的文件["tag1", "tag2"]

程式碼範例

若要檢視使用 $setIsSubset命令的程式碼範例,請選擇您要使用的語言標籤:

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('products'); const result = await collection.find({ $expr: { $setIsSubset: [["tag1", "tag2"], "$tags"] } }).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['products'] result = list(collection.find({ '$expr': {'$setIsSubset': [['tag1', 'tag2'], '$tags']} })) print(result) client.close() example()