3

我想通过按日期累积来计算用户。我有以下地图减少功能:

var m = function(){
    // creation date
    var d = new Date(parseInt(this._id.toString().slice(0,8), 16)*1000);
    // ticks
    var t = d.getTime();
    emit(d2,d3);
};

var r = function(k,v){
    return v[0];    // just go next with ticks
};

var opts = { out :  { merge : "UserAccum", db : "Metric"},
    finalize: function(k,v){
    var str = "parseInt(this._id.toString().slice(0,8), 16)*1000 <= "+v;
    return db.User.count({$where:str});         
} 
};
var res = db.Provider.mapReduce(m, r, opts);

运行时,出现错误:

Sat May 12 17:47:23 uncaught exception: map reduce failed:{
    "assertion" : "invoke failed: JS Error: TypeError: db has no properties
nofile_b:2",
    "assertionCode" : 9004,
    "errmsg" : "db assertion failure",
    "ok" : 0
}

似乎无法调用 db. finalize 里面的方法。为什么?

我知道我可以从 map() 和 reduce() 调用

4

2 回答 2

4

是的,您不能在 map-reduce 函数中运行查询。它们必须只依赖于它们的输入参数。

于 2012-05-12T12:01:22.093 回答
0

您可以在 mapreduce 函数中运行查询,只是 db 是对默认数据库的引用,而不是您正在运行的数据库。

所以你需要这样做: var fdb = db.getSiblingDB('yourdb'); var 结果 = fdb.yourcollection.find(..);

我不知道这是否是新的并且在一年前的版本中不起作用。在这种情况下,“可以”也可能与“应该”不同。

于 2013-08-02T13:44:56.077 回答