MongoDB中的聚合操作

一、介绍

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

二、使用

use users;
db.createCollection("article");
db.article.insert({title:'人生之路',price:800,by_user:'张三'});
db.article.insert({title:'纵有疾风起',price:900,by_user:'张三'});
db.article.insert({title:'山河锦绣',price:1000,by_user:'李四'});
db.article.find();
db.article.drop();

现在我们通过以上集合计算每个作者所写的文章数,使用aggregate()计算结果:

db.article.aggregate([{$group:{_id:"$by_user",num_tutorial:{$sum:1}}}]);

常见聚合表达式: 

如果我们想计算每个作者所写文章的平均售价,则可以使用下述命令:

db.article.aggregate([{$group:{_id:"$by_user",avg_price:{$avg:"$price"}}}]);

db.article.aggregate([{$group:{_id:"$by_user",avg_price:{$min:"$price"}}}]);
db.article.aggregate([{$group:{_id:"$by_user",avg_price:{$max:"$price"}}}]);

三、$unwind

$unwind操作符表示解析输入文档中的数组字段,为每个元素输出一个文档。

3.1 简单使用

利用下述脚本初始化product集合中的文档数据: 

db.product.insertOne({"_id":1,"name":"小米13","version":["青春版","标准版","尊享版"]})

使用下述脚本按照version字段拆分文档数据:

db.product.aggregate([{$unwind:"$version"}]);

3.2 拆分的数组字段是null或者[ ]数据 

利用下述脚本初始化product集合中的文档数据:

db.product.insertMany([
  {"_id":1,"name":"小米13","version":["青春版","标准版","尊享版"]},
  {"_id":2,"name":"苹果14","version":[]},
  {"_
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值