我在 MongoDB 中有这个集合(为简洁起见,我省略了_id
s):
test> db.entries.find();
{
"val": 1
}
{
"val": 2
}
{
"val": 3
}
{
"val": 4
}
{
"val": 5
}
我需要对每个我无法处理的文档进行一些处理db.update()
。因此,简而言之,我需要做的是一次检索一个文档,在 Node 中处理它并将其保存回 Mongo。
我正在使用 Monk 库,并使用 Q 表示承诺。这是我所做的——为简洁起见,我没有包括处理/保存位:
var q = require('q');
var db = require('monk')('localhost/test');
var entries = db.get('entries');
var i = 1;
var total;
var f = function (entry) {
console.log('i = ' + i);
console.log(entry.val);
i++;
if (i <= total) {
var promise = entries.findOne({ val: i });
loop.then(function (p) {
return f(p);
});
return promise;
}
};
var loop = q.fcall(function () {
return entries.count({});
}).then(function (r) {
total = r;
return entries.findOne({ val: i });
}).then(f);
我希望这段代码能打印出来:
i = 1
1
i = 2
2
i = 3
3
i = 4
4
i = 5
5
但它实际上打印出来:
i = 1
1
i = 2
2
i = 3
2
i = 4
2
i = 5
2
我究竟做错了什么?