MongoDB聚合管道:$match

$match是聚合管道中最常用的阶段之一,用于过滤管道中的文档,只允许符合条件的文档进入到管道的下一阶段。

语法

js 复制代码
{$match:{<query>}}

使用举例

创建articles文档,并加入下面的数据

json 复制代码
{ "_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 }

等式匹配

js 复制代码
匹配作者为"dave"的文档
db.articles.aggregate(
    [ { $match : { author : "dave" } } ]
);

管道输出结果:

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

计数

匹配评分在70分到90分之间或者阅读量大于1000的记录,并统计数量

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

管道输出结果:

json 复制代码
{ "_id" : null, "count" : 5 }

最佳实践

  • 应尽可能把$match放在管道的前面,这样可以最大程度的减少进入管道的文档数量,不仅可以减少内存的占用,也可以加快后续阶段的执行。
  • 如果$match放在管道的最前面,就能像find一样利用上索引了,执行效率会更高。

注意事项

  • $matchquery参数跟collection.find查询条件一样,只支持读取操作表达式,不支持原始聚合表达式,只能在$expr查询表达式中包含聚合表达式。比如:

    js 复制代码
    { $match: { $expr: { <aggregation expression> } } }
  • $match中,不能使用$where

  • $match中,不能使用$near$nearSphere,但是:

    • 可以使用$geoNeer替代match
    • $geoWithin可以与$center$centerSphere一起使用
  • 如果要在$match中使用$text,则必须要把$match放在聚合管道的第一个阶段。

内容参考MongoDB官方线上文档,错误纰漏之处请不吝指正。

相关推荐
李强57627825 分钟前
语法制导的语义计算(包含python源码)
java·数据库·python
企销客CRM6 分钟前
企微CRM系统中的任务分配与效率提升技巧
大数据·数据库·人工智能·数据分析·企业微信
Hello.Reader10 分钟前
Redis 延迟排查全攻略
数据库·redis·缓存
jstart千语26 分钟前
【Redisson】锁的可重试原理和看门狗机制
数据库·redis·缓存
听忆.2 小时前
Java修改接口 校验一个或多个字段不可重复(自定义注解)
java·开发语言·数据库
kingbal2 小时前
MySQL:要删除子查询所涉及表中的数据,直接使用原 SQL 会报错
数据库·sql·mysql
GGBondlctrl3 小时前
【Redis】Redis核心探秘:数据类型的编码实现与高速访问之道
数据结构·数据库·redis·缓存·编码方式·redis工作过程·单线程模型
独爱竹子的功夫熊猫4 小时前
数据库技巧:REPLACE INTO的高效替换方法
数据库·后端·mysql
企销客CRM4 小时前
SCRM软件数据分析功能使用指南:从数据挖掘到商业决策
数据库·人工智能·数据挖掘·数据分析·企业微信
cocosum4 小时前
树莓派5 安装Mysql (Docker + mariadb)方案
linux·数据库·mysql·docker·mariadb