数据库
首页 > 数据库> > javascript – node-mysql connection.query()返回undefined

javascript – node-mysql connection.query()返回undefined

作者:互联网

我正在使用基于einaros/ws构建的节点ws服务器.
该服务器必须向数据库发送查询.因为我正在使用felixge/node-mysql.

当用户连接到服务器时,应检查客户端是否仍存在于数据库中.

这是一段有趣的代码:

console.log("client-liste ist leer");
var query = "SELECT name FROM spieler WHERE name='"+id+"' AND passwort='"+passwort+"'";
var result = queryToDatabase(query);
console.log(getTime() + "DB-Result Abfrage: " + result);

以及查询完成的代码:

var mysql = require('mysql');
var mysqlConnection = mysql.createConnection({
    host: dbHost,
    user: dbUser,
    password: dbPassword,
});

function queryToDatabase(anfrage) {
    mysqlConnection.connect();

mysqlConnection.query("USE " + db, function(err, rows, fields) {
    if (err) throw err;
});

mysqlConnection.query(anfrage, function(err, rows, fields) {
        if (err) throw err;
        console.log("rows as String - " + JSON.stringify(rows));
        return rows;

    });

    mysqlConnection.end();
}

控制台中的日志是:

客户端监听
3.8.2012 – 15:29:0 – DB-Result Abfrage:undefined
行作为字符串 – [{“name”:“lukas”}]

有谁理解,为什么函数返回undefined?
我还试图等待Database-Connection完成一个简单的setTimout,但没有改变!

解决方法:

您不能从异步回调中返回值,例如查询使用的值.您需要重写queryToDatabase,以便将回调作为其第二个参数,并在查询成功时使用行调用它.然后你的主要代码需要看起来像:

queryToDatabase(query, function(result) {
     console.log(getTime() + "DB-Result Abfrage: " + result);
   });

实际上,依赖于查询结果的所有代码都需要进入该回调.

实际上,您希望回调采用两个参数:错误状态和结果,如果查询成功,则错误状态为null.

标签:javascript,node-js,undefined,return,node-mysql
来源: https://codeday.me/bug/20190620/1248538.html