簡體   English   中英

貓鼬:查找所有包含在另一個數組中的數組字段的文檔

[英]Mongoose: Find all documents with array field which is included in another array

因此,此示例將是這樣的:

請求對以下數組進行搜索:

    ['banana', 'apple', 'orange', 'mango']

至於我的數據庫,我有一個Recipe集合,其中包含一個字段ingredints是一個數組。

文件#1:

... ingredients: ['banana', 'apple'] ...

文件#2:

... ingredients: ['banana', 'apple', 'orange'] ...

文件#3:

... ingredients: ['apple', 'orange', 'kiwi'] ...

查詢的輸出應返回Document#1和Document#2。 (包含奇異果的文檔#3,初始數組中未包含)。

您可以使用以下聚合:

db.col.aggregate([
    {
        $addFields: {
            matchingElements: { $setIntersection: [ ['banana', 'apple', 'orange', 'mango'], "$ingredients" ] }
        }
    },
    {
        $redact: {
            $cond: {
                if: { $eq: [ { $size: "$ingredients" }, { $size: "$matchingElements" } ] },
                then: "$$KEEP",
                else: "$$PRUNE"
            }
        }
    },
    {
        $project: {
            matchingElements: 0
        }
    }
])

$ setIntersection將為您提供數組中存在的ingredients中的所有項目。 然后,您可以使用$ redact來檢查matchingElements是否具有與ingredients相同的大小,這意味着所有元素都匹配。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM