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

Veg*_* Sv 6 error-handling mongoose mongodb node.js

我正在使用猫鼬:

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

我故意使用一个不存在 xyz 的用户,它没有触发任何错误,我以为是因为 Mongoose,但后来我在 MongoDB shell 中尝试,是的,如果记录不存在,MongoDB 不会返回错误.

>db.accounts.find({username: 'xyz'})
> // no error, blank line
Run Code Online (Sandbox Code Playgroud)

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

sty*_*ane 5

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

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

或者更详细的版本:

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
        }
    }
});
Run Code Online (Sandbox Code Playgroud)