设为首页 收藏本站
查看: 1382|回复: 0

[经验分享] MongoDB中MapReduce不同的写法,不同的结果

[复制链接]

尚未签到

发表于 2015-7-10 09:18:51 | 显示全部楼层 |阅读模式
  MapReduce有两种写法,也可以说mongodb所有的命令行都有两种写法。
  但突然间发现MapReduce不同的写法会有不同的结果,接下来我们一起来看:

第一种:直接使用扩展属性。
  1)emit函数的第2参数直接使用数值。



> db.entities.mapReduce(function(){emit(this.age,1)},function(key,value){var tot
al=0;for(var i in value){total+=value;} return total;},{query:{age:{"$gt":97}
},out:{inline:1}})
{
"results" : [
{
"_id" : 98,
"value" : 10602
},
{
"_id" : 99,
"value" : 11533
}
],
"timeMillis" : 414,
"counts" : {
"input" : 22135,
"emit" : 22135,
"reduce" : 223,
"output" : 2
},
"ok" : 1,
}
  看到results.value是正常值,方法可行。
  2)emit函数的第2参数使用object对象。



> db.entities.mapReduce(function(){emit(this.age,{count:1})},function(key,value)
{var total=0;for(var i in value){total+=value.count;} return total;},{query:{
age:{"$gt":97}},out:{inline:1}})
{
"results" : [
{
"_id" : 98,
"value" : NaN
},
{
"_id" : 99,
"value" : NaN
}
],
"timeMillis" : 643,
"counts" : {
"input" : 22135,
"emit" : 22135,
"reduce" : 223,
"output" : 2
},
"ok" : 1,
}
  
  看到results.value是Nan,证明此方法不可行。
  

第二种方法:使用内置命令函数runCommand。
  1)emit函数的第2参数直接使用数值。



> db.runCommand({mapReduce:"entities",map:function(){emit(this.age,1)},reduce:fu
nction(key,value){var total=0;for(var i in value){total+=value;} return {coun
t:total,key:key};},query:{age:{$gt:97}},out:{inline:1}})
{
"results" : [
{
"_id" : 98,
"value" : {
"count" : "0[object Object]11",
"key" : 98
}
},
{
"_id" : 99,
"value" : {
"count" : "0[object Object]111111111111111111111
11111111111111",
"key" : 99
}
}
],
"timeMillis" : 383,
"counts" : {
"input" : 22135,
"emit" : 22135,
"reduce" : 223,
"output" : 2
},
"ok" : 1
}
  
  看到results.value是竟然是这样的,证明此方法不可行。
  2)emit函数的第2参数使用object对象。



> db.runCommand({mapReduce:"entities",map:function(){emit(this.age,{count:1})},r
educe:function(key,value){var total=0;for(var i in value){total+=value.count;
} return {count:total,key:key};},query:{age:{$gt:98}},out:{inline:1}})
{
"results" : [
{
"_id" : 99,
"value" : {
"count" : 11533,
"key" : 99
}
}
],
"timeMillis" : 388,
"counts" : {
"input" : 11533,
"emit" : 11533,
"reduce" : 116,
"output" : 1
},
"ok" : 1
}
  
  看到results.value是正常值,方法可行。
  
  为什么会这样?原因以后再补上。
  结论:
  1、使用扩展函数db.xx.mapreduce时,emit函数的第2参数必须是使用数值。
  2,使用内置命令函数db.runCommand时,emit函数的第2参数必须object对象。程序内部运行就是使用此方法。
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-85048-1-1.html 上篇帖子: MongoDB —— 第五篇 主从复制 下篇帖子: Cent OS 5.6下安装MongoDB教程
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表