Mongodb中group参数怎样使用,有哪些选项
Admin 2022-11-22 群英技术资讯 705 次浏览
// 准备测试数据 db.user.drop(); for(var i=10; i25的用户,按照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: 这是个函数,每一组文档执行完后,多会触发此方法。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Limit与Skip在MongoDB中是经常需要使用到的,但是对于Limit与Skip的使用方法并不是所有用户们都了解,那么你知道MongoDB中如何使用Limit与Skip吗?如果还不了解的小伙伴们不妨一起看看吧。
下面三招确实比较实用,内容来自Conversocial公司的VP Colin Howe在London MongoDB用户组的一个分享。申请:下面几点并非放四海皆准的法则,具体是否能够使用,还需要根据自己的应用场景和数据特点来决定。
mongodb适用于存储日志,通过MongoDB存储日志文件,查询简单(索引),写入导出方便(弹性结构没有表结构限制)。
这篇文章主要给大家分享MongoDB数据库命令,总结了很多MongoDB常用数据库命令及用法,具有一定的借鉴价值,感兴趣的朋友可以参考参考,下面就跟随小编一起来看看吧。
今天給大家分享一些MongoDB中比较好玩的知识吧,主要是聚合,游标,那闲话不多说,附上这篇MongoDB初学者关于聚合和游标操作的教程,聚合和游标可以说是MongoDB中的高级操作了,需要的朋友不可错过喔!
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008