mapReduce 结果问题

liycumt 2015-04-02 12:19:08
1、创建集合
for(i=0;i<200;i++){db.numbers.save({num:i})}
db.numbers.insert({num:0})
db.numbers.insert({num:1})
db.numbers.insert({num:3})

2、mapReduce
编写a.js文件

var m=function()
{
emit(this.num,{cc:1});
}

var r=function(key,values)
{
return {"res":values};
}

db.numbers.mapReduce(m,r,{out:"gres"})


执行
mongo -u liye -p aaaa --authenticationDatabase testa 127.0.0.1/testa D:\mongodb\bin\a.js

3、查看结果

> db.gres.find()
{ "_id" : 0, "value" : { "res" : [ { "cc" : 1 }, { "cc" : 1 } ] } }
{ "_id" : 1, "value" : { "res" : [ { "cc" : 1 }, { "cc" : 1 } ] } }
{ "_id" : 2, "value" : { "cc" : 1 } }
{ "_id" : 3, "value" : { "res" : [ { "cc" : 1 }, { "cc" : 1 } ] } }
{ "_id" : 4, "value" : { "cc" : 1 } }
{ "_id" : 5, "value" : { "cc" : 1 } }
{ "_id" : 6, "value" : { "cc" : 1 } }
{ "_id" : 7, "value" : { "cc" : 1 } }
{ "_id" : 8, "value" : { "cc" : 1 } }
{ "_id" : 9, "value" : { "cc" : 1 } }
{ "_id" : 10, "value" : { "cc" : 1 } }
{ "_id" : 11, "value" : { "cc" : 1 } }

只有 0、1、3 value是数组,且节点名称是res,和预期一致;而类似1个的(2、4、5、6)value文档的节点名称确是cc,也不是数组。请问原因。
...全文
115 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

1,798

社区成员

发帖
与我相关
我的任务
社区描述
MongoDB相关内容讨论区
社区管理员
  • MongoDB社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧