我正在尝试构建一个应用程序,它要求我为每个视图/控制器创建多个查询。
我试图使用嵌套结构异步执行,但是sql结果在内部闭包中未定义。
这是我用来做这个的功能:
var conn = db.config(mysql);
function run_queries(conn,callback) {
conn.query(sql1, var1, function(err, res1) {
if(err){ callback(err); return; }
console.log(res1); // RETURNS SUCCESSFULLY!
conn.query(sql2, var2, function(err, res2) {
if(err){ callback(err); return; }
console.log(res2); // UNDEFINED :(
callback(null, res2);
});
});
}
run_queries(conn,function(err, result){
console.log(result); // UNDEFINED :(
});
我检查了我的SQL,它没有错误。如果我将sq1与sq2交换,则外部闭包返回sq2的正确查询。
内部闭包只是不返回查询。
答案 0 :(得分:2)
异步对于异步调用非常有用。您可以使用异步模块很好地维护代码。
使用async.parallel
var conn = db.config(mysql);
var async = require('async');
function run_queries(conn, cb) {
async.parallel({
res1: function (cb) {
conn.query(sql1, var1, function (err, res1) {
if (err) { cb(err) }
else { cb(null, res1) }
})
},
res2: function (cb) {
conn.query(sql2, var2, function (err, res2) {
if (err) { cb(err) }
else { cb(null, res2) }
})
}
},
function (err, result) {
if (err) { cb(err) }
else { cb(null, result) }
})
}
run_queries(conn, function (err, result) {
console.log(result); // UNDEFINED :(
// GET OBJECT OF res1 AND res2
});