MongoDB Node.js按计算密钥分组

MongoDB Node.js group by calculated key

本文关键字:密钥 计算 Node js MongoDB      更新时间:2023-09-26

我是Mongo Node.js驱动程序的新手。我的问题是,我在Mongo中设置了一个时间戳(以毫秒为单位)字段,现在我尝试按秒对其进行分组。时间戳是一个数字(Int64),我想把它分组并除以1000进行计数。

我的MongoDB Shell查询运行良好:

db.default.group(
{
    keyf: function(doc) {
    var secs = (doc.timestamp/1000).toFixed();
    return {'data':secs};
    },
    cond: {source:1},
    initial: {count:0},
    reduce: function(obj, prev) {prev.count++;}
})

我的问题是我无法处理Node.js查询:

var keyf = function(doc) {
        var secs = (doc.timestamp/1000).toFixed();
        return {'data': secs};
};
collection.group(keyf, {}, {"count":0},
      "function(obj, prev){prev.count++;}", false, function(err,results) {
    console.log(results);
});

看起来好像小组从未注意到keyf函数。有什么想法吗?

collection上没有.group方法,或者您必须使用型号

Model.find({}, function(err, docs) { 
    if(err) console.error(err);
    if(!docs) console.log("No docs found!");
    function updater(docs){
        // Get first item of documents 
        doc = docs.unshift();
        // Change
        doc.timestamp = (doc.timestamp/1000).toFixed();
        // Update
        doc.save(function(err){
            if(err)
                console.log(err);
            else
                updater(docs); 
        });
    }
    // Update documents in async
    updater(docs);
});