mongoDB中聚合(aggregate)的具体使用
先来看一个分组的例子,本例中$group是一个管道操作符,获得的结果可以接着输出到下一个管道,而内部的$sum是一个表达式操作符。
参考链接
https://www.jianshu.com/p/72fc4409936c
用$group 举个例子
将document分组,用作统计结果 ``` db.Ubisoft.aggregate([ // aggregate方法接收的是一个数组 { $group: { _id: '$time', num: {$sum: 1} } } ]) // 这里的_id字段表示你要基于哪个字段来进行分组(即制定字段值相同的为一组),这里的$time就表示要基于time字段来进行分组 // 下面的num字段的值$sum: 1表示的是获取满足time字段相同的这一组的数量乘以后面给定的值(本例为1,那么就是同组的数量)。 ```
那么看完这个例子之后,mongoDB中还有其他的一些管道操作符和表达式操作符:
管道操作符
常用管道 含义
$group 将collection中的document分组,可用于统计结果
$match 过滤数据,只输出符合结果的文档
$project 修改输入文档的结构(例如重命名,增加、删除字段,创建结算结果等)
$sort 将结果进行排序后输出
$limit 限制管道输出的结果个数
$skip 跳过制定数量的结果,并且返回剩下的结果
$unwind 将数组类型的字段进行拆分
表达式操作符
常用表达式 含义 $sum 计算总和,{$sum: 1}表示返回总和×1的值(即总和的数量),使用{$sum: '$制定字段'}也能直接获取制定字段的值的总和 $avg 平均值 $min min $max max $push 将结果文档中插入值到一个数组中 $first 根据文档的排序获取第一个文档数据 $last 同理,获取最后一个数据
我们现在来试试其他的表达式操作符:
#数据结果 /* 1 */ { "_id" : ObjectId("5b0cf67270e4fa02d31de42e"), "name" : "rainbowSix Siege", "time" : 400.0 } /* 2 */ { "_id" : ObjectId("5b0cf69270e4fa02d31de42f"), "name" : "Assassin's creed", "time" : 20.0 } /* 3 */ { "_id" : ObjectId("5b0cf6ad70e4fa02d31de430"), "name" : "ghost Recon", "time" : 0.0 } /* 4 */ { "_id" : ObjectId("5b0d14c870e4fa02d31de436"), "name" : "farCry", "time" : 0.0 } # 查询方法push db.Ubisoft.aggregate([ { $group: { _id: '$time', gameName: {$push: '$name'} } } ]) ]) 返回结果为: /* 1 */ { "_id" : 20.0, "gameName" : [ "Assassin's creed" ] } /* 2 */ { "_id" : 0.0, "gameName" : [ "ghost Recon", "farCry" ] } /* 3 */ { "_id" : 400.0, "gameName" : [ "rainbowSix Siege" ] }
分类:
mongo
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通