所以这个例子就是这样的:
请求搜索以下数组:
['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)。
答案 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
具有相同的大小,这意味着所有元素都匹配。