香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > Mongodb >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

MongoDB学习笔记之分组(group)使用示例


时间:2020-11-14 13:36 作者:admin610456


// 准备测试数据db.user.drop();for(var i=10; i< 100; i++) {  db.user.insert({    name:"user" + i,     age : Math.floor(Math.random()*10)+ 20,     sex : Math.floor(Math.random()*3)%2 ==0 ? 'M' : 'F',    chinese : Math.floor(Math.random()*50)+50,    math : Math.floor(Math.random()*50)+50,    english : Math.floor(Math.random()*50)+50,    class : "C" + i%5  })}// group函数// 按照class进行分组,显示每个class中的用户姓名和性别db.user.group({  key: {"class": true},  initial: {"person": []},  reduce: function(cur, prev) {    prev.person.push({name: cur.name, sex: cur.sex, age: cur.age});  }});// 对age>25的用户,按照class进行分组,显示每个class中的用户姓名和性别,并统计每组的人数db.user.group({  key: {"class": true},  initial: {"person": []},  reduce: function(doc, out){    out.person.push({name: doc.name, sex: doc.sex, age: doc.age});  },  finalize: function(out){    out.count = out.person.length;  },  condition: {"age": {$gt: 25}}})// 分组计算每个class中,chinese最大值和最小值db.user.group({  key: {"class": true},  initial: {"chinese_min": 0, "chinese_max":0 },  reduce: function(doc, out){    out.chinese_min = doc.chinese;    out.chinese_min = doc.chinese;    out.chinese_min = Math.min(out.chinese_min, doc.chinese);    out.chinese_max = Math.max(out.chinese_max, doc.chinese)  },})// 利用分组,计算每个总成绩和成绩平均值db.user.group({  key: {"_id" : true},  initial: {name:"", total: 0, avg: 0},  reduce: function(doc, out){    out.name = doc.name;    out.total = doc.chinese + doc.math + doc.english;    out.avg = Math.floor(out.total / 3);  }})

group参数选项:

1.key: 这个就是分组的key
2.initial: 每组都分享一个初始化函数,特别注意:是每一组initial函数。
3.reduce: 这个函数的第一个参数是当前的文档对象,第二个参数是上一次function操作的累计对象。有多少个文档, $reduce就会调用多少次。
4.condition: 这个就是过滤条件。
5.finalize: 这是个函数,每一组文档执行完后,多会触发此方法。

(责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)