## 聚合 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登陸完善