MongoDB学习笔记--分组(1)
来源:互联网 发布:建筑工程定额软件手机 编辑:程序博客网 时间:2024/06/05 18:47
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参数选项:
- key: 这个就是分组的key
- initial: 每组都分享一个初始化函数,特别注意:是每一组initial函数。
- reduce: 这个函数的第一个参数是当前的文档对象,第二个参数是上一次function操作的累计对象。有多少个文档, $reduce就会调用多少次。
- condition: 这个就是过滤条件。
- finalize: 这是个函数,每一组文档执行完后,多会触发此方法。
0 0
- MongoDB学习笔记--分组(1)
- mongoDB学习笔记1
- MongoDB学习笔记-1
- MongoDB学习笔记1
- Mongodb学习笔记1-Mongodb的安装
- mongoDB学习笔记1--安装
- MongoDB学习笔记1(入门)
- MongoDB学习笔记(1)
- MongoDB学习笔记(1)
- MongoDB学习笔记 - Aggregation (1)
- MongoDB学习笔记(1)
- mongoDB分组
- MongoDB分组
- MongoDB学习笔记1--MongoDB的windows安装记录
- MongoDB学习笔记之 第1章 MongoDB的安装
- flask + MongoDB 学习笔记(1) : MongoDB配置和使用
- MongoDB学习笔记:(1)、MongoDB在Win10下的安装
- MongoDB学习笔记:(1)、MongoDB在Win10下的安装
- android调用系统相机拍照并裁剪
- 联网查看图片
- Tomcat配置文件---配置访问指定路径下的项目
- android gradle task dependence
- 猜猜看
- MongoDB学习笔记--分组(1)
- JavaScript学习
- page cache 和 buffer cache的区别
- 2012年5月SAT香港真题解析
- 谓词(NSPredicate)
- head.First.python:注册pypi、上传代码、更新代码
- sql统计某一字段等于不同值的个数
- C#去除HTML标记,包括HTML的源码
- UVA 10723--Cyborg Genes+最长公共子序列变形