我有几个正在运行 mapreduce 的 Mongoid 模型,我想将统一的结果存储在一个daily_stats
集合中。我的 map & reduce 函数适用于所有 3 个模型,但即使输出 via collection.mapreduce(map, reduce, {:out => "daily_stats", :raw => true})
,后续 map reduce 操作的结果也会覆盖以前的结果,即使它们没有重叠键:
{'_id': "2012-06-01", 'values': {photos: 10}}
{'_id': "2012-06-02", 'values': {photos: 10}}
当后续传递返回时,get 的值photos
被抛出:
{'_id': "2012-06-01", 'values': {comments: 1}}
{'_id': "2012-06-02", 'values': {comments: 6}}
我也尝试与 合并collection.mapreduce(map, reduce, {:out => {:merge => "daily_stats"}, :raw => true})
,但这似乎也不起作用。
有任何想法吗?
更新
每个模型的 map 和 reduce 函数都是这样的:
地图:
function() {
day = Date.UTC(this.created_at.getFullYear(), this.created_at.getMonth(), this.created_at.getDate());
emit(day, {users: 1});
};
减少:函数(键,值){ var users_added_count = 0;
values.forEach(function(v) {
users_added_count += parseInt(v['users']) || 0;
});
return {users: users_added_count};
}
以下是有关生成的架构的一些额外信息:
{ "_id" : 1337040000000,
"value" : {
"apartments" : 280,
"price" : 1003653,
"photos" : 83,
"comments" : 0 }
}