SQL和Node:如何运行三个不同的查询并逐个返回结果



我总共有3个SQL查询。我已经通过node.js完成了与数据库的连接。如何编写一个函数来帮助我逐一运行所有3个查询,并将结果以json形式返回到angular前端。

这是我的密码。有没有更好的方法可以逐个调用查询作为返回。我对api使用post方法。

var sqlquery=" " 
var sqlsecond=" "
var sqlthird=" "
mysqlConnection.query(sqlquery,(err,result)=>{
if(err){
console.log("Error"+err);
}
else{
return response.json(result);
}
selectquery2(sqlsecond)
selectquery3(sqlthird)
})
})
function selectquery2(sqlquery1){
mysqlConnection.query(sqlquery1,(err,result1)=>{
if(err){
console.log("Error"+err);
}
else{
return response.json(result1);
}
})
}
function selectquery3(sqlquery2){
mysqlConnection.query(sqlquery2,(err,result2)=>{
if(err){
console.log("Error"+err);
}
else{
return response.json(result2);
}
})
}

您可以使用Promise并准备好所有3个结果,然后以json格式一起返回所有结果。例如

router.get('/', async function(req, response){
try{
var sqlquery=" " 
var sqlsecond=" "
var sqlthird=" "
let result1 = await selectquery(sqlquery)
let result2 = await selectquery(sqlsecond)
let result3 = await selectquery(sqlthird)
return response.json({result1:result1, result2:result2, result3:result3});
}
catch(err){
response.status(500).end();
}
})

async function selectquery(sqlquery){
return new Promise((resolve, reject) => {
mysqlConnection.query(sqlquery,(err,result)=>{
if(err){
reject(err);
}
else{
resolve(result);
}
});
});
}