获取数组中特定条件至少有两个值的文档,在 MongoDB 中查询
Get documents with at least two values for a especific condition in an Array, Query in MongoDB
假设您在 this structure 中有一个集合。
{ "_id" : ObjectId("5f21a77c52efa009cc9857a7"), "results" : [ 76, 72, 93 ] },
{ "_id" : ObjectId("5f21a993b4d13477dd950904"), "results" : [ 90, 94, 80 ] },
{ "_id" : ObjectId("5f21a9a0b4d13477dd950905"), "results" : [ 70, 73, 99 ] },
{ "_id" : ObjectId("5f21a9abb4d13477dd950906"), "results" : [ 91, 85, 99 ] }
我正在使用 Mongodb 指南针。
我想查找其 results
数组包含至少两项大于 90 的文档。
我试过这样做:
{$or:[{$and:[ {"results.0": { $gte : 90 } },{"results.1": { $gte : 90 } } ]}, {$and: [ {"results.1": { $gte : 90 } },{"results.2": { $gte : 90 } } ]}, {$and: [ {"results.0": { $gte : 90 } },{"results.2": { $gte : 90 } } ]}]}
通过这个查询,我得到了这个 result
我想知道是否有做同样事情的“优化查询”!
提前致谢!
您必须 $filter 数组只包含匹配项,然后检查它的大小:
db.collection.aggregate([
{
$addFields: {
tmp: {
$filter: {
input: "$results",
as: "res",
cond: {
$gte: [
"$$res",
90
]
}
}
}
}
},
{
$match: {
"tmp.1": {
$exists: true
}
}
},
{
$project: {
tmp: 0
}
}
])
假设您在 this structure 中有一个集合。
{ "_id" : ObjectId("5f21a77c52efa009cc9857a7"), "results" : [ 76, 72, 93 ] },
{ "_id" : ObjectId("5f21a993b4d13477dd950904"), "results" : [ 90, 94, 80 ] },
{ "_id" : ObjectId("5f21a9a0b4d13477dd950905"), "results" : [ 70, 73, 99 ] },
{ "_id" : ObjectId("5f21a9abb4d13477dd950906"), "results" : [ 91, 85, 99 ] }
我正在使用 Mongodb 指南针。
我想查找其 results
数组包含至少两项大于 90 的文档。
我试过这样做:
{$or:[{$and:[ {"results.0": { $gte : 90 } },{"results.1": { $gte : 90 } } ]}, {$and: [ {"results.1": { $gte : 90 } },{"results.2": { $gte : 90 } } ]}, {$and: [ {"results.0": { $gte : 90 } },{"results.2": { $gte : 90 } } ]}]}
通过这个查询,我得到了这个 result
我想知道是否有做同样事情的“优化查询”! 提前致谢!
您必须 $filter 数组只包含匹配项,然后检查它的大小:
db.collection.aggregate([
{
$addFields: {
tmp: {
$filter: {
input: "$results",
as: "res",
cond: {
$gte: [
"$$res",
90
]
}
}
}
}
},
{
$match: {
"tmp.1": {
$exists: true
}
}
},
{
$project: {
tmp: 0
}
}
])