聚合:
主要用于计算和统计等,类似sql种的sum() avg()
db.集合.aggregate( { 管道:{表达式} } ) 常用的管道:
$group:将集合中的文档按照字段进行分组
$match:过滤数据,输出符合条件的文档
$project:修改文档的结构,重命名、增加、删除字段,创建结果,类似投影,指定字段显示结果
$sort:排序
$limit:限制返回文档条数
$skip:跳过指定数量的文档
$unwind:对列表类型字段内容拆分 常用表达式: $表达式:"$字段"
$sum:计算总数量,$sum:1 代表按照1倍进行统计总数量
$avg:计算平均值
$min:获取最小值
$max:获取最大值
$push:结果文档插入到一个数组给配合分组使用
$first:获取排序后第一个文档数据
$last:获取排序后最后一个文档数据 $group: {_id:"$字段"} 指定字段分组,id为null代表全部数据为一组
例如:统计男生、女生的人数
db.stu.aggregate(
{$group:{
_id:"$gender", //按照gender进行排序
total:{$sum:1} //自己设置一个字段total用于保存统计每个组的人数
// $sum:1 代表按照一倍进行统计总数量
}}
) _id:null 代表所有数据分为一组
例如: 求总人数和平均年龄
db.stu.aggregate(
{$group:{
_id:null, //整个数据分为一组
total:{$sum:1}, //按照一倍统计总数量
avg_age:{$avg:"$age"} //按照字段年龄求平均数
}}
) $push: 透视数据,将符合分组条件的字段插入到结果列表当中,"$$ROOT"可以令整个文档插入列表
例如:按照性别统计姓名:
db.stu.aggregate(
{$group:{
_id:"$gender", //按照性别进行分组
names:{$push:"$name"} //将符合分组的name字段值插入 names的列表里
}}
) 例如: 按照性别,统计文档
db.stu.aggregate(
{$group:{
_id:"$gender", //按照性别进行分组
info:{$push:"$$ROOT"} //将符合分组的文档插入到info列表当中
}}
) $match: 过滤数据,输出符合条件的文档
例如:查询年龄大于20的学生
db.stu.aggregate(
{$match:{age:{$gt:20}}} //年龄大于20
) 例如:查询年龄大于20的男生女生分别的人数。(多个管道进行并列)
db.stu.aggregate(
{$match:{age:{$gt:20}}}, //年龄大于20 筛选出符合条件的数据
{$group:{
_id:"$gender", //按照性别分组
total:{$sum:1} //求出总数量
}}
) $project: 类似投影,指定字段进行显示结果
例如: 查询学生的姓名、年龄
db.stu.aggregate(
{$project:{
_id:0,
name:1, //指定为1代表显示,指定为0代表不显示
age:1
}}
) 例如:查询男女生,输出人数
db.stu.aggregate(
{$group:{ //按照性别分组后统计人数
_id:"$gender",
total:{$sum:1}
}},
{$project:{
_id:0, //指定只输出总数 不输出_id
total:1
}}
) $sort: 排序后输出,1为升序 -1为降序
例如: 查询学生信息,按年龄升序
db.stu.aggregate(
{$sort:{age:1}}
) 例如: 查询男女生的人数并按人数降序
db.stu.aggregate(
{$group:{ //按年龄排序求出总人数
_id:"$gender",
total:{$sum:1}
}},
{$sort:{total:-1}} //按照total的降序排列
) $skip和$limit:
$skip:num 越过前num条文档
$limit:num 显示num条文档
先skip再limit实现分页的功能 例如:查询3到7条(略过前2条,查询5条)
db.stu.aggregate(
{$skip:2},
{$limit:5}
) $unwind:对文档中包含列表类型按照列表内元素个数数据进行拆分成多条
构造数据:db.t2.insert({_id:1,item:'t-shirt',size:['S','M','L']})
拆分: db.t2.aggregate( {$unwind:"$size"} )
结果: { "_id" : 1, "item" : "t-shirt", "size" : "S" }
{ "_id" : 1, "item" : "t-shirt", "size" : "M" }
{ "_id" : 1, "item" : "t-shirt", "size" : "L" } 处理空数组、非数组、无字段、null情况:(按如上操作会丢失查询结果)
需要指定preserveNullAndEmptyArrays: true代表保留空文档,false代表不保留空文档
构造数据:db.t3.insert([
{ "_id" : 1, "item" : "a", "size": [ "S", "M", "L"] },
{ "_id" : 2, "item" : "b", "size" : [ ] },
{ "_id" : 3, "item" : "c", "size": "M" },
{ "_id" : 4, "item" : "d" },
{ "_id" : 5, "item" : "e", "size" : null }
])
丢数据的拆分: db.t3.aggregate({ $unwind:"$size" })
空的size仍然保留信息: db.t3.aggregate({ $unwind:"$size",preserveNullAndEmptyArrays:true })

mongodb聚合的使用的更多相关文章

  1. MongoDB 聚合管道(Aggregation Pipeline)

    管道概念 POSIX多线程的使用方式中, 有一种很重要的方式-----流水线(亦称为"管道")方式,"数据元素"流串行地被一组线程按顺序执行.它的使用架构可参考 ...

  2. Mongodb学习笔记四(Mongodb聚合函数)

    第四章 Mongodb聚合函数 插入 测试数据 ;j<;j++){ for(var i=1;i<3;i++){ var person={ Name:"jack"+i, ...

  3. mongodb MongoDB 聚合 group

    MongoDB 聚合 MongoDB中聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果.有点类似sql语句中的 count(*). 基本语法为:db.col ...

  4. MongoDB 聚合

    聚合操作过程中的数据记录和计算结果返回.聚合操作分组值从多个文档,并可以执行各种操作,分组数据返回单个结果.在SQL COUNT(*)和group by 相当于MongoDB的聚集. aggregat ...

  5. MongoDB聚合

    --------------------MongoDB聚合-------------------- 1.aggregate():     1.概念:         1.简介             ...

  6. MongoDB 聚合分组取第一条记录的案例及实现

    关键字:MongoDB: aggregate:forEach 今天开发同学向我们提了一个紧急的需求,从集合mt_resources_access_log中,根据字段refererDomain分组,取分 ...

  7. mongodb MongoDB 聚合 group(转)

    MongoDB 聚合 MongoDB中聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果.有点类似sql语句中的 count(*). 基本语法为:db.col ...

  8. mongodb聚合 group

    MongoDB中聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果.有点类似sql语句中的 count(*). 基本语法为:db.collection.agg ...

  9. MongoDB 聚合(管道与表达式)

    MongoDB中聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果.有点类似sql语句中的 count(*). aggregate() 方法 MongoDB中 ...

  10. 【Mongodb教程 第十一课 】MongoDB 聚合

    聚合操作过程中的数据记录和计算结果返回.聚合操作分组值从多个文档,并可以执行各种操作,分组数据返回单个结果.在SQL COUNT(*)和group by 相当于MongoDB的聚集. aggregat ...

随机推荐

  1. windows中安装redis

    Redis是有名的NoSql数据库,一般Linux都会默认支持.但在Windows环境中, Windows的Redis安装包需要到以下GitHub链接找到.链接:https://github.com/ ...

  2. map/vector erase

    问题核心:erase之后迭代器是否失效 vector调用erase之后,该迭代器之后的迭代器都失效: map调用erase之后,其他迭代器并不会失效. vector<int> vecDat ...

  3. 共享MFC每周时间选择控件代码

    自己写的周时间选择控件,原理就是在Static上用GDI画图. 支持选择每周内每一天内的任意时间段,可以任意拖动修改时间段,任意合并时间段 效果如下图: VS2012代码下载:https://gith ...

  4. C++模板类与Qt信号槽混用

    一.正文 目前正在做一个视频处理相关的项目.项目的技术栈是这样的,UI层采用Qt来实现基本的数据展示和交互,底层音视频采用的是一套基于FFmpeg的视频处理框架.这是一套类似Microsoft Med ...

  5. Mycat 分片规则详解--ER关系表分片

    ER模型是实体关系模型,基本元素是实体.关系和属性,Mycat 针对ER关系表的切分规则中,使得有相互依赖的表能够按照某一个规则切分到相同的节点上,避免垮库 Join 关系查询,下面的示例为订单(or ...

  6. python基础学习笔记二之列表

    1.列表 ①列表的创建: ②列表的查询(索引): ③列表的切片操作: 此处要注意到:返回索引0到3的元素,顾头不顾尾. ④列表的增加: s.append()  #直接在结尾追加 s.insert()  ...

  7. linux --> 获取进程执行时间

    获取进程执行时间 一.时间概念 在linux下进行编程时,可能会涉及度量进程的执行时间.linux下进程的时间值分三种: 时钟时间(real time):指进程从开始执行到结束,实际执行的时间. 用户 ...

  8. (工具类)double类型数据运算

    package com.flf.util;import java.math.BigDecimal;/** * double类型数据运算 * @author Yancy 2016-12-14 * */p ...

  9. linux小白成长之路3————更新yum源

    [内容指引] 进入目录:cd 查看目录下的内容:ls 重命名备份:mv 从网络下载:wget yum更新:yum update 第一次运行yum安装软件前,建议更新yum. 1.进入yum源目录 命令 ...

  10. JavaScript 哈希表(散列表)应用

    查找的效率与比较次数密切相关.基于比较的程序,运算效率是比较低的.比如平时可以通过indexOf查找一个数据.但这是一个基于比较的一个实现.如果是淘宝那样有上亿个商品,那么用indeOf 来查数据就会 ...