主页 > 知识库 > MongoDB学习笔记之分组(group)使用示例

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

热门标签:Linux服务器 百度竞价排名 铁路电话系统 呼叫中心市场需求 网站排名优化 地方门户网站 服务外包 AI电销
// 准备测试数据
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: 这是个函数,每一组文档执行完后,多会触发此方法。

您可能感兴趣的文章:
  • MongoDB 学习笔记(一)-MongoDB配置
  • MongoDB学习笔记(六) MongoDB索引用法和效率分析
  • MongoDB学习笔记(五) MongoDB文件存取操作
  • MongoDB学习笔记—Linux下搭建MongoDB环境
  • MongoDB学习笔记(一) MongoDB介绍与安装方法
  • MongoDB学习笔记(三) 在MVC模式下通过Jqgrid表格操作MongoDB数据
  • MongoDB学习笔记(四) 用MongoDB的文档结构描述数据关系
  • MongoDB学习笔记(二) 通过samus驱动实现基本数据操作
  • Windows下MongoDB的下载安装、环境配置教程图解
  • MongoDB的下载、安装与部署方法
  • MongoDB系列教程(三):Windows中下载和安装MongoDB
  • mongodb数据库入门学习笔记之下载、安装、启动、连接操作解析

标签:崇左 衡水 仙桃 铜川 兰州 湘潭 黄山 湖南

巨人网络通讯声明:本文标题《MongoDB学习笔记之分组(group)使用示例》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266