我有以下的Logincount.js。
请告诉我如何在创建集合LoginCount时包含日期字段?
现在,js文件创建了一个包含两个字段的集合,即_id和value
我希望它还创建一个名为date的字段,其中包含昨天的日期。
这是我的js文件
m = function() { emit(this.cust_id, 1); }
r = function (k, vals) { var sum = 0; for (var i in vals) { sum += vals[i]; } return sum; }
q = function() {
var currentDate = new Date();
currentDate.setDate(currentDate.getDate()-1);
var month = (currentDate.getMonth() < 9 ? "0"+ (currentDate.getMonth()+1) : (currentDate.getMonth()+1));
var day = (currentDate.getDate() < 10 ? "0" + currentDate.getDate() : currentDate.getDate());
var date = currentDate.getTime();
var patt = date;
var query = {"created_at":patt};
return query;
}
res = db.user_logins.mapReduce(m, r, { query : q(), out : "LoginCount" });
答案 0 :(得分:1)
据我所知,MapReduce生成的集合中的仅字段是_id和value - 这只是MapReduce的本质。也许您可以在输出集合上运行更新“扁平化”值字段?