如果记录不存在,MongoDB find 不返回错误?
问题:如果记录不存在,MongoDB find 不返回错误? 我正在使用猫鼬: user.find({username: 'xyz'}, function(err, doc){ if(err){ res.render('error', {errorMsg: "Error blah blah"}) } }); 我故意使用不存在 xyz 的用户并且它没有触发任何错误,我认为这是因为 Mongoose
·
问题:如果记录不存在,MongoDB find 不返回错误?
我正在使用猫鼬:
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
我该如何处理?如果用户不存在,我希望脚本的执行停止。
解答
好吧,如果“用户名”不存在,那并不意味着有错误。相反,你应该做这样的事情。
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
}
}
});
更多推荐
已为社区贡献32870条内容
所有评论(0)