Docs 菜单

$match(聚合)

$match

筛选文档,以便只将符合特定条件的文档传递到下一管道阶段。

可以使用 $match 查找托管在以下环境中的部署:

$match 阶段具有以下原型形式:

{ $match: { <query> } }

$match 接受一个指定查询条件的文档。查询语法与读取操作查询语法相同,即 $match 不接受原始聚合表达式。请使用 $expr 查询表达式将聚合表达式包含在 $match 中。

要在查询谓词中包含表达式,请使用 $expr 操作符。

如果满足以下条件之一,则 $match 阶段会从管道结果中过滤掉文档:

  • $match查询谓词返回该文档的 0nullfalse 值。

  • $match查询谓词使用了该文档中缺少的字段。

  • $match 查询语法与读取操作查询语法相同,即 $match 不接受原始聚合表达式。要在 $match 中包含聚合表达式,请使用 $expr 查询表达式:

    { $match: { $expr: { <aggregation expression> } } }
  • 您不能将 $where 用在 $match 查询中作为聚合管道的一部分。

  • 不能将 $match 查询中的 $near$nearSphere 用作该聚合管道的一部分。或者也可以:

  • 要在 $match 阶段使用 $text$match 阶段必须是管道的第一阶段。

    视图不支持 $text

    注意

    $text 提供自管理(非 Atlas)部署的文本查询功能。对于托管在 MongoDB Atlas 上的数据,MongoDB 提供了一种改进的全文查询解决方案 Atlas Search

对于存储在 MongoDB Atlas 中的数据,在运行 $search 查询时,您可以使用 Atlas Search 复合操作符 filter 选项来匹配或过滤文档。在 $search 之后运行 $match,相比使用复合操作符 filter 选项运行 $search 的性能更低。

要了解有关 filter 选项的更多信息,请参阅 Atlas 文档中的 compound

这些示例会使用包含以下文档且名为 articles 的集合:

{ "_id" : ObjectId("512bc95fe835e68f199c8686"), "author" : "dave", "score" : 80, "views" : 100 }
{ "_id" : ObjectId("512bc962e835e68f199c8687"), "author" : "dave", "score" : 85, "views" : 521 }
{ "_id" : ObjectId("55f5a192d4bede9ac365b257"), "author" : "ahn", "score" : 60, "views" : 1000 }
{ "_id" : ObjectId("55f5a192d4bede9ac365b258"), "author" : "li", "score" : 55, "views" : 5000 }
{ "_id" : ObjectId("55f5a1d3d4bede9ac365b259"), "author" : "annT", "score" : 60, "views" : 50 }
{ "_id" : ObjectId("55f5a1d3d4bede9ac365b25a"), "author" : "li", "score" : 94, "views" : 999 }
{ "_id" : ObjectId("55f5a1d3d4bede9ac365b25b"), "author" : "ty", "score" : 95, "views" : 1000 }

以下操作使用 $match 来执行简易等值匹配:

db.articles.aggregate(
[ { $match : { author : "dave" } } ]
);

$match 会选择 author 字段等于 dave 的文档,而聚合返回以下内容:

{ "_id" : ObjectId("512bc95fe835e68f199c8686"), "author" : "dave", "score" : 80, "views" : 100 }
{ "_id" : ObjectId("512bc962e835e68f199c8687"), "author" : "dave", "score" : 85, "views" : 521 }

以下示例使用 $match 管道操作符选择要处理的文档,然后将结果导入到 $group 管道操作符,以计算文档的数量:

db.articles.aggregate( [
{ $match: { $or: [ { score: { $gt: 70, $lt: 90 } }, { views: { $gte: 1000 } } ] } },
{ $group: { _id: null, count: { $sum: 1 } } }
] );

在聚合管道中,$match 选择 score 大于 70 但小于 90views 大于或等于 1000 的文档。然后,这些文档通过管道传送到 $group 进行计数。该聚合返回以下内容:

{ "_id" : null, "count" : 5 }