Mongodb 查询耗时过长

Posted

技术标签:

【中文标题】Mongodb 查询耗时过长【英文标题】:Mongodb query taking too long 【发布时间】:2016-03-03 09:40:35 【问题描述】:

我正在尝试掌握 Mongodb,现在,我有一个非常小的集合,只有几百条记录,我想在未来使用 javascript 动态更新一些字段。但是,虽然现在文档太少,但下面的查询和更新至少需要 24 秒。一旦我们投入生产并有大量文件要更新,我认为这对我没有任何用处。任何人都可以帮助我解决下面的代码有什么问题?

提前致谢

var d = new Date();
var sapm = 1.8;
i = 0;
db.getCollection('content').find().forEach(function(x) 

    var window = (d - x.updated_at) / (24 * 60 * 60 * 1000);
    var feed = db.content.find(, 
        _id: x._id
    );
    var comment = x.total_comment || 0;
    var up = x.total_up || 0;
    var interaction = up + (comment / 2);
    var hourage = (d - (x.updated_at));
    var rank = interaction / Math.pow((hourage - 4) * sapm);

    if (window <= 15) 
        db.content.update(
            '_id': x._id
        , 

            $set: 
                "rank": rank,
            
        , 
            multi: true
        );
    
);

【问题讨论】:

非常感谢。我现在不能投票,但你帮我省了很多麻烦。 我已将其添加为答案 【参考方案1】:

您的查询速度很快,只是单独更新每个文档需要时间。

您应该将所有要更新的文档推送到一个数组中,然后使用 async.js 之类的东西并行保存/更新。

【讨论】:

以上是关于Mongodb 查询耗时过长的主要内容,如果未能解决你的问题,请参考以下文章

MongoDB 查询执行时间过长

Mongodb $near 查询 120 万份文档耗时 6 秒

Mongodb聚合$group阶段耗时较长

MongoDB-pymongo.errors.CursorNotFound: Cursor

PostgreSQL 查询耗时过长

使用 HAVING 查询耗时过长