簡體   English   中英

Mongodb查詢花費太長時間

[英]Mongodb query taking too long

我正在嘗試擺脫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
        });
    }
});

您的查詢速度很快,這是單獨更新每個文檔所花費的時間。

您應該將所有文檔更新到一個數組中,然后使用async.js之類的東西來並行保存/更新。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM