在mongodb中有时候我们需要对数据进行分析操作,比如一些统计操作,这个时候简单的查询操作(find)就搞不定这些需求,因此就需要使用 聚合框架(aggregation) 来完成。在mongodb中提供了三种方式来完成聚合操作。aggregation pipeline map-reduce function, and single purpose aggregation methods,本篇文章主要讲解aggregation pipeline(聚合管道)的使用。
Aggregation Pipeline(聚合管道)
MongoDB的聚合框架基于数据处理管道的概念。文档进入一个多级管道,将文档转换为聚合结果。比如文档的投影,过滤,排序,分组,等等。此外,管道阶段还可以使用操作符来执行任务,例如计算平均值或连接字符串等等。
下图为一个简单的聚合例子(此图来自mongodb的官网)
如上图所示:先使用 $match 构建筛选出 status 等于A 的数据,然后使用 $group 构建分组数据,以 cust_id 进行分组,使用 $sum 进行分组的求和操作。
聚合管道的限制
1、文档大小限制
聚合的返回单个文档不可超过16M,但是聚合的过程中单个文档可以超过16M.
2、内存的限制
聚合阶段默认情况下可以使用100M的内存,超过则报错。如果想处理需要超过100M内存的数据,则需要将 allowDiskUse
设置成 true,让其可以写入临时文件。但是在 $graphLookup
阶段,内存还是限制到100M以内,即使设置了 allowDiskUse=true, 在此管道阶段会失效,但是如果以其他的管道阶段还是会生效的。当allowDiskUser=false,内存超出发生异常。
聚合管道阶段
$match | 用于过滤数据,用于聚合阶段的输入 |
$order | 用指定的键,对文档进行排序 |
$limit | 用于限制多少个文档作为输入 |
$skip | 跳过多少个文档 |
$project | 投影字段,可以理解为查询多少个字段,类似为 select a,b,c 中的 a,b,c |
$group | 进行分组操作,其中_id字段用于指定需要分组的字段。 |
$count | 返回这个聚合管道阶段的文档的数量 |
更多管道阶段,请点击 这里。
聚合管道操作,请点击 这里
基本语法
db.collection.aggregate( [ { <stage> }, ... ] )
准备数据
db.persons.insertMany([ {userId : '001',age : 24,salary : 5000,dept : '部门一'}, {userId : '002',age : 25,salary : 7000,dept : '部门二'}, {userId : '003',age : 23,salary : 8000,dept : '部门一'}, {userId : '004',age : 26,salary : 1000,dept : '部门三'}, {userId : '005',age : 27,salary : 2000,dept : '部门二'}, {userId : '006',age : 22,salary : 7000,dept : '部门一'}, {userId : '007',age : 25,salary : 6000,dept : '部门三'}, {userId : '008',age : 26,salary : 4000,dept : '部门三'}, {userId : '009',age : 28,salary : 9000,dept : '部门二'} ])
1、使用 $project 投影出需要的字段
* 排除 _id 字段
* 返回 age字段
* 产生一个新字段 newAge,它的值为原age字段的值 加 1
db.persons.aggregate([ {$project : {_id : 0,age : 1,newAge : {$add : ['$age',1]}}} ])
2、使用 $match 进行数据的过滤
和普通的查询条件是一样的。
db.persons.aggregate([ {$match : {age : {$gt : 22}} } ])
3、使用 $sort 进行排序
db.persons.aggregate([ {$match : {age : {$gt : 22}} }, {$sort : {age : 1}} ])
4、使用 $limit 和 $skip 进行限制数据和过滤数据
db.persons.aggregate([ {$match : {age : {$gt : 22}} }, {$sort : {age : -1}}, {$limit : 6}, {$skip : 3} ])
5、使用 $group 进行分组操作
db.persons.aggregate([ {$group : {_id : "$dept",count : {$sum : 1}}} ]);
有了以上的简单知识,我们完成一个简单的练习。
需求: 获取6个年龄大于22周岁的用户,其中如果薪水如果小于1000,直接将薪水上调到4000,前面一步做好后,需要排出年龄最大的一个,求出每个部门,相同年龄的员工的平均薪水,并得到薪水最高的三个人。
思路:1、投影出年龄(age),部分(dept),薪水(salary)字段
2、查出年龄大于22周岁的员工
3、以年龄倒叙进行排序
4、限制返回7条数据,并跳过一条数据
5、以部门年龄进行分组,并求出平均分
6、以上一步的平均分在进行倒叙排序
7、然后再返回3条数据
代码如下
db.persons.aggregate([ { $project : {age : 1,dept : 1,oldSalary : "$salary",salary : { $switch : { branches : [ { case : { $lte : ["$salary",1000] }, then : {$sum : ["$salary",4000]}} ], default : '$salary' } }} }, { $match : {age : {$gt : 22}} }, { $sort : {age : -1}}, { $limit : 7}, { $skip : 1 }, { $group : { _id : {dept : "$dept",age : "$age"},pers : {$sum : 1} , deptAvgSalary : { $avg : "$salary"} } }, { $sort : {deptAvgSalary : -1}}, { $limit : 3} ]);
运行效果
相关推荐
11、MongoDB聚合操作及索引使用详解_ev.rar11、MongoDB聚合操作及索引使用详解_ev.rar11、MongoDB聚合操作及索引使用详解_ev.rar11、MongoDB聚合操作及索引使用详解_ev.rar11、MongoDB聚合操作及索引使用详解_ev.rar...
聚合操作使得MongoDB不仅能够存储大量动态格式的数据,还能够高效地对这些数据进行复杂分析。 聚合框架强大的数据处理能力,不仅限于基本的数据聚合,还包括对文本数据的聚合,通过$geoNear进行地理空间数据聚合等...
聚合操作案例2-资源
接下来,我们将详细地探讨MongoDB聚合管道的相关知识点。 首先,从概念上理解,MongoDB的聚合管道可以类比为一个数据处理的“流水线”,每个阶段(Stage)可以看作是流水线上的一个节点,文档会按顺序地通过这些...
### MongoDB 聚合框架详解 #### 概述 MongoDB 的聚合框架是数据库系统中一个强大而灵活的功能,用于处理复杂的数据分析需求。通过一系列的管道操作(pipeline stages),可以实现对数据集进行筛选、分组、计算等...
day4:教你学会MongoDB聚合操作 day5:索引的特性及应用 day6:MongoDB实例搭建仓位管理API day7:数据模型优化及设计 day8:复制集介绍及演练 day9:海量数据分片 day10:数据库认证与授权介绍及演练 day11:MongoDB数据库...
读者将学习到聚合管道的概念,以及如何使用各种操作符(如 `$match`、`$group`、`$sort` 等)来过滤、投影、排序和处理数据。这部分内容还包括聚合管道的执行顺序,帮助读者理解数据是如何在管道中流动并被逐步处理...
然后,`MongoTemplate`的`aggregate()`方法执行聚合操作,返回`AggregationResults`对象,可以进一步处理得到的结果。 总的来说,Spring Data MongoDB的聚合功能使得开发者能够轻松地在Java代码中实现复杂的数据...
- **SQL到聚合映射表**: 为熟悉SQL的用户提供了从SQL到MongoDB聚合操作的映射指南。 ### 聚合接口与命令 - **聚合方法**: 包括各个版本中引入的新的聚合方法和特性。 - **聚合命令**: 提供了各类聚合命令的参考。 ...
"Mongo聚合助手类似于lodash实用程序"这个标题暗示了一个专门针对MongoDB聚合操作的工具或模块,它可能模仿了lodash的接口和风格,使得开发者可以更方便地进行数据处理。 在JavaScript开发中,lodash的便捷性在于其...
7. **聚合框架**: Spring Data MongoDB还提供了对MongoDB聚合操作的支持,允许开发者构建复杂的聚合管道,处理数据并返回聚合结果。 8. **地理空间索引和查询**: MongoDB支持地理空间索引,Spring Data MongoDB也...
MongoDB的聚合操作允许用户对数据进行复杂的数据处理,例如计算总和、平均值、过滤、分组等。聚合框架由一系列管道阶段组成,每个阶段都会对输入文档进行处理并传递给下一个阶段。常见的管道阶段包括: 1. `$match`...
聚合查询是 MongoDB 中的一种强大查询方式,通过对数据进行分组、过滤、排序等操作,可以快速地获取所需的数据。在 JAVA 中使用 MongoDB 时,通常使用 Spring Data MongoDB 框架来实现聚合查询。在本文中,我们将...
MongoDB的聚合框架提供了内置的聚合操作,如 `$first` 和 `$last`,可以用于在一个聚合管道中直接获取每个分组的第一个或最后一个文档。然而,在这个案例中,由于需要基于 `createTime` 的最新记录,因此需要额外的...
8. **聚合框架**:Spring Data MongoDB提供了对MongoDB聚合操作的支持,允许开发者构建复杂的聚合管道,以分析和处理数据。 9. **数据分片**:在大型分布式环境中,Spring Data MongoDB可以帮助配置和管理MongoDB的...
3. **高性能**:MongoDB优化了读写操作,提供了高性能的数据访问,特别是在处理大量的读写操作时。 4. **高可用性**:通过副本集(Replica Sets)实现,副本集是一组维护相同数据集的MongoDB服务器,可以提供数据的...
以上两种情况的聚合统计,分别对应与聚合框架中的 $group 操作步骤和 $project 操作步骤。 1.$group 直接看例子吧。 Case 1 测试集合mycol中的数据如下: { title: 'MongoDB Overview', description: 'MongoDB is...
在本教程中,我们将深入探讨MongoDB中的三个关键聚合操作:`count`、`distinct`和`group`。 1. `count` 函数: `count` 方法用于计算集合中符合特定条件的文档数量。在MongoDB中,你可以直接调用`db.collection....