[英]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.