如果记录不存在,MongoDB find不会返回错误?

时间:2016-06-09 15:22:09

标签: node.js mongodb error-handling mongoose

我正在使用Mongoose:

user.find({username: 'xyz'}, function(err, doc){
  if(err){
    res.render('error', {errorMsg: "Error blah blah"})
  }
});

我故意使用不存在xyz且没有触发任何错误的用户,我认为这是因为Mongoose然后我在MongoDB shell中尝试过,是的,如果记录没有,MongoDB将不会返回错误不存在。

>db.accounts.find({username: 'xyz'})
> // no error, blank line

我该如何处理?如果用户不存在,我希望脚本的执行停止。

3 个答案:

答案 0 :(得分:2)

var user = db.accounts.findOne({username: 'xyz'});

if (!user) {
   // handle error
   alert('fail');
}

答案 1 :(得分:2)

好吧,如果“用户名”不存在,那并不意味着有错误。相反,你应该做这样的事情。

user.find({ username: 'xyz' }, function(err, doc){
  if(doc.length === 0 || err){
    res.render('error', { errorMsg: "Error blah blah" } )
  }
});

或更详细的版本:

user.find({ username: 'xyz' }, function(err, doc) {
    if(err){
        res.render('error', { errorMsg: "Error blah blah" } )
    } else {
        if (doc.length === 0) {
            console.log("User doesn't exist");
        } else {
            //do something
        }
    }
});

答案 2 :(得分:0)

首先尝试检查文档是否为空,然后您可以继续使用您的功能。

user.find({ username: 'xyz' }, function(err, doc){
   if(doc === null || err){
      res.render('error', { errorMsg: "Error blah blah" } )
   }
   else {
      do something...
    }
});