MongoDB——聚合管道
Posted 小志的博客
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MongoDB——聚合管道相关的知识,希望对你有一定的参考价值。
目录
一、什么是 MongoDB 聚合框架
- MongoDB 聚合框架(Aggregation Framework)是一个计算框架,它可以:
(1)、作用在一个或几个集合上;
(2)、对集合中的数据进行的一系列运算;
(3)、将这些数据转化为期望的形式; - 从效果而言,聚合框架相当于 SQL 查询中的GROUP BY、 LEFT OUTER JOIN 、 AS等。
二、管道(Pipeline)和阶段(Stage)
2.1、管道(Pipeline)和阶段(Stage)的概述
- 整个聚合运算过程称为管道(Pipeline),它是由多个阶段(Stage)组成的, 每个管道:
(1)、接受一系列文档(原始数据);
(2)、每个阶段对这些文档进行一系列运算;
(3)、结果文档输出给下一个阶段;
2.2、官网文档地址
2.3、聚合管道操作语法
-
聚合管道操作语法:
pipeline = [$stage1, $stage2, ...$stageN]; db.collection.aggregate(pipeline, options)
-
pipelines 一组数据聚合阶段。除 o u t 、 out、 out、Merge和$geonear阶段之外,每个阶段都可以在管道中出现多次。
-
options 可选,聚合操作的其他参数。包含:查询计划、是否使用临时文件、 游标、最大操作时间、读写策略、强制索引等等
2.4、常用的管道聚合阶段
阶段 | 描述 | SQL等价运算符 |
---|---|---|
$match | 筛选条件 | WHERE |
$project | 投影 | AS |
$lookup | 左外连接 | LEFT OUTER JOIN |
$sort | 排序 | ORDER BY |
$group | 分组 | GROUP BY |
$skip 或者 $limit | 分页 | |
$unwind | 展开数组 | |
$graphLookup | 图搜索 | |
$facet 或者 $bucket | 分面搜索 |
以上是关于MongoDB——聚合管道的主要内容,如果未能解决你的问题,请参考以下文章