## 聚合 aggregate
* 聚合(aggregate)主要用于计算数据,类似sql中的sum()、avg()
* 语法
~~~
db.集合名称.aggregate([{管道:{表达式}}])
~~~
## 管道
* 管道在Unix和Linux中一般用于将当前命令的输出结果作为下一个命令的输入
~~~
ps ajx | grep mongo
~~~
* 在mongodb中,管道具有同样的作用,文档处理完毕后,通过管道进行下一次处理
* 常用管道
* $group:将集合中的文档分组,可用于统计结果
* $match:过滤数据,只输出符合条件的文档
* $project:修改输入文档的结构,如重命名、增加、删除字段、创建计算结果
* $sort:将输入文档排序后输出
* $limit:限制聚合管道返回的文档数
* $skip:跳过指定数量的文档,并返回余下的文档
* $unwind:将数组类型的字段进行拆分
## 表达式
* 处理输入文档并输出
* 语法
~~~
表达式:'$列名'
~~~
* 常用表达式
* $sum:计算总和,$sum:1同count表示计数
* $avg:计算平均值
* $min:获取最小值
* $max:获取最大值
* $push:在结果文档中插入值到一个数组中
* $first:根据资源文档的排序获取第一个文档数据
* $last:根据资源文档的排序获取最后一个文档数据
- mysql
- 1.创建库和表
- 1.1.数据库简介
- 1.2.安装管理
- 1.3.数据完整性
- 1.4.命令脚本操作
- 2.查询
- 2.1.条件
- 2.2.聚合
- 2.3.分组
- 2.4.排序
- 2.5.分页
- 3.高级
- 3.1.关系
- 3.2.连接
- 3.3.自关联
- 3.4.子查询
- 3.5.内置函数
- 3.6.视图
- 3.7.事务
- 4.与python交互
- 4.1.交互类型
- 4.2.增改删
- 4.3.查询
- 4.4.封装
- 4.5.用户登录
- Nosql简介
- mongodb
- 1.基本操作
- 1.1.环境安装
- 1.2.数据库操作
- 1.3.集合操作
- 1.4.数据类型
- 1.5.数据操作
- 1.6.数据查询
- 1.6.1.Limit与Skip
- 1.6.2.投影
- 1.6.3.排序
- 1.6.4.统计个数
- 1.6.5.消除重复
- 2.高级操作
- 2.1.聚合aggregate
- 2.1.1.$group
- 2.1.2.$match
- 2.1.3.$project
- 2.1.4.$sort
- 2.1.5.$limit,$skip
- 2.1.6.$unwind
- 2.2.安全
- 2.3.复制(副本集)
- 2.4.备份和恢复
- 2.5.与python交互
- redis
- 1.基本配置
- 2.数据操作
- 2.1.string
- 2.2.键命令
- 2.3.hash
- 2.4.list
- 2.5.set
- 2.6.zset
- 4.高级
- 4.1.发布订阅
- 4.2.主从配置
- 5.与python交互
- 6.login登陆完善