管道的概念
管道在Unix和Linux中一般用于将当前命令的输出结果作为下一个命令的参数。
MongoDB的聚合管道将MongoDB文档在一个管道处理完毕后将结果传递给下一个管道处理。管道操作是可以重复的。
表达式:处理输入文档并输出。表达式是无状态的,只能用于计算当前聚合管道的文档,不能处理其它的文档。
这里我们介绍一下聚合框架中常用的几个操作:
- $project:修改输入文档的结构。可以用来重命名、增加或删除域,也可以用于创建计算结果以及嵌套文档。主要用于过滤集合元素。
- $match:用于过滤数据,只输出符合条件的文档。$match使用MongoDB的标准查询操作。
- $limit:用来限制MongoDB聚合管道返回的文档数。
- $skip:在聚合管道中跳过指定数量的文档,并返回余下的文档。
- $unwind:将文档中的某一个数组类型字段拆分成多条,每条包含数组中的一个值。
- $group:将集合中的文档分组,可用于统计结果。
- $sort:将输入文档排序后输出。1是按照升序输出,-1按照降序输出。
- $geoNear:输出接近某一地理位置的有序文档。
$project$match$sort的引用:
eg:
$update:更新文档。
只更新第一条记录:
db.col.update( { "count" : { $gt : 1 } } , { $set : { "test2" : "OK"} } );
全部更新:
db.col.update( { "count" : { $gt : 3 } } , { $set : { "test2" : "OK"} },false,true );
$option:
option参数的含义:
选项 | 含义 | 使用要求 |
---|---|---|
i | 大小写不敏感 | |
m |
查询匹配中使用了锚,例如^(代表开头)和$(代表结尾),以及匹配n后的字符串 |
|
x |
忽视所有空白字符 |
要求$regex与$option合用 |
s | 允许点字符(.)匹配所有的字符,包括换行符。 | 要求$regex与$option合用 |