首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在NodeJS中从MYSQL返回布尔值

在NodeJS中从MYSQL返回布尔值
EN

Stack Overflow用户
提问于 2017-12-27 14:00:38
回答 1查看 4.1K关注 0票数 1

我正在处理一个函数,它将返回一个布尔值。如果数据库中存在用户,则此值表示。目前,我有以下几点:

代码语言:javascript
运行
复制
function checkIfExists(){
    var sql = "SELECT * FROM Users WHERE user = " + mysql.escape(req.body.username);
    var rows = 0;
    database.query(sql, function(err, result, fields){
      console.log(result.length);
      rows += result.length;
    });
    return rows > 0;
  }

  console.log(checkIfExists());

我使用'console.log(result.length)‘来验证是否有结果。当我测试一些输入时,我得到了以下信息:

代码语言:javascript
运行
复制
false
1

这很奇怪,因为只有一个结果,所以行应该等于1,但是它返回false而不是true。行的值在“database.query(.”)中不可能更改吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-12-27 14:15:06

因为您的函数checkIfExists是异步的,所以我认为您应该使用这样的回调系统:

代码语言:javascript
运行
复制
function checkIfExists(callback) {
    var sql = "SELECT * FROM Users WHERE user = " + mysql.escape(req.body.username);
    var rows = 0;
    database.query(sql, function (err, result, fields) {
        if (err) {
            callback(err, null);
        }
        else {
            console.log(result.length);
            rows += result.length;
            callback(null, rows > 0);
        }
    });
}

checkIfExists(function(err, isExists) {
    if (err) {
        // An error occured
    }
    else {
        console.log(isExists);
    }
});

编辑

您还可以将您的checkIfExists函数简化如下:

代码语言:javascript
运行
复制
function checkIfExists(callback) {
    var sql = "SELECT * FROM Users WHERE user = " + mysql.escape(req.body.username);
    database.query(sql, function (err, result) {
        callback(err, result ? result.length > 0 : false);
    });
}

这里有更多信息:理解Node.js中的异步编程

希望能帮上忙。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47993499

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档