[英]SQL and Node: How can I run three different query and return the result one by one
我總共有3個SQL查詢。 我已經通過node.js完成了與數據庫的連接。 我如何編寫一個函數來幫助我一個接一個地運行所有3個查詢,並將結果作為json返回到有角前端。
這是我的代碼。 有沒有更好的方法來調用查詢作為返回然后一個接一個地調用。 我正在使用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);
}
});
});
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.