首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

mongodb mapreduce分析(5)

mongodb mapreduce分析(5)

二:求分组后小组的记录条数(这里我们用国家来分组)

db.runCommand({ mapreduce: "c",
map : function Map() {


emit(
  this.country,     // how to group
  {count: 1} // associated data point (document)
);


},
reduce : function Reduce(key, values) {

      Total=0;


values.forEach(function(val) {
   Total += val.count;
});

return Total;




},
finalize : function Finalize(key, reduced) {


return reduced;
},
out : { inline : 1 }
});



结果:



分析:map函数中emit函数分组,用country当key。有两个小组:中国和澳大利亚。在reduced里求每一个小组的总数。返回。 可以得到一共有中国有7条记录,澳大利亚有2条记录
返回列表