gpt4 book ai didi

javascript - 节点js : unable to return value from a function

转载 作者:行者123 更新时间:2023-11-28 04:52:47 24 4
gpt4 key购买 nike

我无法理解如何从 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com