0

基本上,我试图找出一种方法来在 for 循环中执行一堆查询,然后在它们全部完成后执行某些操作。

我让它工作了,但这只是因为我使用了这个很棒的库,它用 Promise 包装了所有 mongodb。

var mongo = require('mongod') 
var db = mongo('mongodb://localhost/builder', ['block''])
var block_ids = ['538d097bbb12479d0e9f70ab', '538ddc7d06c1f0fe296178b1'];

var prom = null;
var blocks = [];
for (i in block_ids) {
    var block_id = block_ids[i];
    prom = db.block.findOne({_id:db.ObjectId(block_id)})
    .then(function(results) {
        blocks.push(results);
    })
}
prom.done(function() {
    console.dir(blocks)
    console.log("DONE! " + blocks.length)
})

我的问题是这个。在没有承诺的情况下,你到底怎么能做类似的事情?好像会很辛苦!

4

2 回答 2

2

愚蠢的for循环

var mongo = require('mongod') 
var db = mongo('mongodb://localhost/builder', ['block''])
var block_ids = ['538d097bbb12479d0e9f70ab', '538ddc7d06c1f0fe296178b1'];


Q(block_ids.map(function(block_id) {
    return db.block.findOne({_id:db.ObjectId(block_id)});
})).all().done(function(blocks) {
    console.dir(blocks)
    console.log("DONE! " + blocks.length)
});

我让它工作了,但这只是因为我使用了这个很棒的库,它用 Promise 包装了所有 mongodb。

bluebird 中,您可以直接完成promisifyAll(require("mongodb"))而不是等待某人制作模块。

于 2014-06-04T09:08:24.860 回答
1

您可以只使用一个简单的变量来计算响应的数量,如下所示:

var responses = 0;
var blocks = [];

for(var i=0; i<block_ids.length; i++) {
   var block_id = block_ids[i];
   db.block.findOne({_id:db.ObjectId(block_id)}, function (err, result) {
       if(err) {
         console.log(err);
       }
       responses++;
       blocks.push[result];

       if (responses === block_ids.length-1) {
           console.log('all find queries have responded');
           // do whatever
       }

   }
}
于 2014-06-04T05:07:36.480 回答