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


// 准备测试数据
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: 这是个函数,每一组文档执行完后,多会触发此方法。



相关阅读:
win7 adsl连接设置方法 win7 adsl自动连接设置教程
原生JS实现旋转木马式图片轮播插件
Android中findViewById获取控件返回为空问题怎么解决
C++设计模式之代理模式
Javascript实现视频轮播在pc端与移动端均可
PHP mysqli 增强 批量执行sql 语句的实现代码
jQuery+HTML5美女瀑布流布局实现方法
win7系统打开IE浏览器提示“禁用的加载项,网页内容无法显示”的故障分析及解决方法
MongoDB使用指南--基本操作
C++输入输出注意事项总结
继续使用Win10过期版本(build 10240之前的版本) 或有什么后果?
js字符串截取函数substr substring slice使用对比
Android非XML形式动态生成、调用页面的方法
自动检测数字替换非数字的正则表达式
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 幸福快乐的旅游 假如中国人的思想不那么封建作文650字 那一句生日快乐! 关于描写班级同学的小学生作文_给我印象最深的人 长荡湖的一天作文 也许……友谊作文600字 三年级语文教师工作总结 闲言碎语集--时间(田晓峰) 寂寞顺水推舟 美在大自然作文750字 破阵子.舞雪 人生这堂课需要实践 媳妇,我该如何去面对你的生活?! 知不知,只缘心之所属 马鲁夫被宰相伤害 建设局绿化管护工人先进事迹 琴之韵作文1000字 母爱=奇迹 学校劳动器材管理规定 村官个人工作计划-农村农业工作计划_农村农业工作计划 爱要及时说出口 杨花 班级半年工作计划 有悲有喜的体育课 图书活动策划书_策划书 女孩向男孩表白的话语 关于社区服务老干部工作的调查与思考 体检(外一首) “笨”鸟1000字作文 我是一个自信的孩子作文450字 诗歌集;对不起,爱上你都我的错 时间小偷 2015淘宝中秋节活动方案 小学2012年春季学期德育工作总结 遇见你 已很美 亲爱的,我们都将这样长大 【精品】大学生支教心得 母爱似水,似阳,似岸 教你贫嘴骂人不带脏字_骂人顺口溜 长吉图开发开放先导区一体化发展战略发展的路径 读《礼物》有感作文600字 中学生关于寒假见闻作文800字 俞敏洪:用商业力量推动中国进步 描写优美景色的好段大全 学十八大报告体会:彰显公平正义的执政新蓝图 QQ作文450字 办公用品销售合同样本 高尔夫联谊赛企划案 英语重默 国庆节演讲稿大全 (八篇)

Copyright © 2016 phpStudy |