一、介绍
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