本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。
$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命令的程式碼範例,請選擇您要使用的語言標籤: