使用MongoDB的本机ES6承诺

时间:2015-09-25 23:50:24

标签: javascript node.js mongodb babeljs es6-promise

我知道Mongo的Node驱动程序可以使用外部库promisified。我很想知道ES6承诺是否可以与MongoClient.connect一起使用,所以我尝试了这个(使用Babel 5.8.23进行转换):

import MongoClient from 'mongodb';

function DbConnection({
  host = 'localhost',
  port = 27017,
  database = 'foo'
}) {
  return new Promise((resolve, reject) => {
    MongoClient.connect(`mongodb://${host}:${port}/${database}`, 
    (err, db) => {
      err ? reject(err) : resolve(db);
    });
  });
}

DbConnection({}).then(
  db => {
    let cursor = db.collection('bar').find();
    console.log(cursor.count());
  },
  err => {
    console.log(err);
  }
);

输出为{Promise <pending>}。与游标有关的任何事情似乎都会产生类似的结果。有没有办法解决这个问题,还是我完全咆哮错误的树?

编辑:节点版本4.1.0。

2 个答案:

答案 0 :(得分:10)

没有什么可以解决的,这是预期的行为。 cursor.count()会返回一个承诺,如果您想要该值,则需要使用.then,例如

DbConnection({}).then(
 db => {
    let cursor = db.collection('bar').find();
    return cursor.count();
  }
}).then(
  count => {
    console.log(count);
  },
  err => {
    console.log(err);
  }
);

或简化

DbConnection({}).then(db => db.collection('bar').find().count()).then(
  count => console.log(count),
  err => console.log(err)
);

答案 1 :(得分:0)

loganfsmyth响应的另一种语法(顺便说一句,谢谢)

cursor.count().then(function(cursor_count){
  if(cursor_count){
    // use cursor
  }else{
    // no results
  }
}