作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我无法理解如何从 Node js 中的函数获取返回值。请找到下面的代码(我能够在控制台日志中获取查询结果,但无法找到如何返回该值并将其存储到调用函数后的任何变量中)
调用函数main:
dbConnection("xxx","xxx","xxx","xxx","50000","select xxx,xxx,CURRENCY from xxx where AccountID='85433333'")
设置数据库连接的函数:
function dbConnection(dbname,hostname,UserID,Password,Port,query,callback)
{
var ibmdb = require('ibm_db');
ibmdb.open("DATABASE="+dbname+";HOSTNAME="+hostname+";UID="+UserID+";PWD="+Password+";PORT="+Port+";PROTOCOL=TCPIP", function (err,conn)
{
if (err) return console.log(err);
var a= executeQuery(conn,query,function(err,data)
{
return data
});
});
}
执行查询的函数:
function executeQuery(conn,query,cb)
{
conn.query(query, function (err, data)
{
if (err) console.log(err,data);
else
console.log(data);
});
//return callback(data);
};
最佳答案
这是一个异步函数,因此您需要使用回调来返回,如下所示。并像这样调用
dbConnection("xxx","xxx","xxx","xxx","50000","select xxx,xxx,CURRENCY from xxx where AccountID='85433333'", function(err, data) {
console.log(data)
})
function dbConnection(dbname,hostname,UserID,Password,Port,query,callback)
{
var ibmdb = require('ibm_db');
ibmdb.open("DATABASE="+dbname+";HOSTNAME="+hostname+";UID="+UserID+";PWD="+Passw ord+";PORT="+Port+";PROTOCOL=TCPIP", function (err,conn)
{
if (err) return console.log(err);
var a= executeQuery(conn,query,function(err,data)
{
callback(err, data)
});
});
}
关于javascript - 节点js : unable to return value from a function,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42784857/
我是一名优秀的程序员,十分优秀!