Mongoose:查找包含在另一个数组

时间:2018-03-29 10:48:09

标签: arrays mongodb api mongoose

所以这个例子就是这样的:

请求搜索以下数组:

    ['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)。

1 个答案:

答案 0 :(得分:1)

您可以使用以下聚合:

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具有相同的大小,这意味着所有元素都匹配。