首页 > 解决方案 > 获取具有至少两个值的文档,用于数组中的特定条件,在 MongoDB 中查询

问题描述

假设您在此结构中有一个集合。

{ "_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 } } ]}]}

通过这个查询,我得到了这个结果

我想知道是否有“优化查询”来做同样的事情!提前致谢!

标签: databasemongodbmongodb-compass

解决方案


您必须$filter数组以仅包含匹配的项目,然后检查它的大小:

db.collection.aggregate([
  {
    $addFields: {
      tmp: {
        $filter: {
          input: "$results",
          as: "res",
          cond: {
            $gte: [
              "$$res",
              90
            ]
          }
        }
      }
    }
  },
  {
    $match: {
      "tmp.1": {
        $exists: true
      }
    }
  },
  {
    $project: {
      tmp: 0
    }
  }
])

Mongo游乐场


推荐阅读