fre*_*fig 4 javascript return undefined node.js node-mysql
我正在使用在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);
Run Code Online (Sandbox Code Playgroud)
以及查询完成的代码:
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();
}
Run Code Online (Sandbox Code Playgroud)
控制台中的日志是:
client-liste ist leer
3.8.2012 - 15:29:0 - DB-Result Abfrage:未定义的
行为String - [{"name":"lukas"}]
有谁理解,为什么函数返回undefined?我还试图等待Database-Connection完成一个简单的setTimout,但没有改变!
您不能从异步回调中返回值,就像使用的那样query.您需要重写queryToDatabase,以便将回调作为其第二个参数,并rows在查询成功时调用它.然后你的主要代码需要看起来像:
queryToDatabase(query, function(result) {
console.log(getTime() + "DB-Result Abfrage: " + result);
});
Run Code Online (Sandbox Code Playgroud)
实际上,依赖于查询结果的所有代码都需要进入该回调.
实际上,您希望回调采用两个参数:错误状态和结果,null如果查询成功,则错误状态为.
| 归档时间: |
|
| 查看次数: |
8127 次 |
| 最近记录: |