Arrays Mongoose:查找包含在另一个数组中的数组字段的所有文档

Arrays Mongoose:查找包含在另一个数组中的数组字段的所有文档,arrays,mongodb,api,mongoose,Arrays,Mongodb,Api,Mongoose,这个例子是这样的: 正在请求对以下阵列执行搜索: ['banana', 'apple', 'orange', 'mango'] 至于我的数据库,我有一个Recipe集合,其中包含一个字段ingredints——作为一个数组 文件#1: 。。。 配料:[‘香蕉’、‘苹果’] ... 文件#2: 。。。 配料:[‘香蕉’、‘苹果’、‘橘子’] ... 文件#3: 。。。 配料:[‘苹果’、‘橘子’、‘猕猴桃’] ... 查询的输出应返回文档#1和文档#2。(文档#3包含未包含在初始数

这个例子是这样的:

正在请求对以下阵列执行搜索:

    ['banana', 'apple', 'orange', 'mango']
至于我的数据库,我有一个
Recipe
集合,其中包含一个字段
ingredints
——作为一个数组

文件#1:

。。。
配料:[‘香蕉’、‘苹果’]
...

文件#2:

。。。
配料:[‘香蕉’、‘苹果’、‘橘子’]
...

文件#3:

。。。
配料:[‘苹果’、‘橘子’、‘猕猴桃’]
...


查询的输出应返回文档#1和文档#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
        }
    }
])

将为您提供阵列中存在的
成分
中的所有项目。然后,您可以使用来检查
匹配元素
是否与
成分
大小相同,这意味着所有元素都匹配。

似乎很清楚。但是如果配料字段实际上是一个对象数组呢?例如:配料:[{..name:'apple'..},{..name:'orange'..}]现在应该如何编写$setIntersection?@Gusti您可以将第一阶段的
$contracents
替换为
{$map:{input:$contracents”,作为:“$$contracents.name”中的“配料”}}
用于仅获取名称字段并创建新数组的对象