javascript – node-mysql connection.query()返回undefined
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – node-mysql connection.query()返回undefined,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1483字,纯文字阅读大概需要3分钟。
内容图文
![javascript – node-mysql connection.query()返回undefined](/upload/InfoBanner/zyjiaocheng/907/8e3cd80c9f1b4297a33dca751ffb1e2c.jpg)
我正在使用基于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-mysql connection.query()返回undefined全部内容,希望文章能够帮你解决javascript – node-mysql connection.query()返回undefined所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。