亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

關于async/await的疑問

關于async/await的疑問

長風秋雁 2019-03-07 14:09:46
希望等待一步操作完成之后,再往下執行 為啥這個不行async function f(mysql_con){        await mysql_con.query("select * from stu_detail where stu_no = ?",['2015130'],async function(err,result,fields){            console.log(result)            console.log(q.sql)            if(result.length == 0){                console.log("數據為空");                await mysql_con.query("insert into stu_detail set ?",{stu_no:"2015130"},function(err,result,fields){                    console.log(a.sql)                    if(err){                        console.log(err)                    }                    console.log("charu")                    console.log(result)                                    })                        }else{                await  mysql_con.query("update stu_detail set ?",{stu_name:"陳翰軒"});            }        for(var i=0;i<fields.length;i++){            // console.log(fields[i])            console.log(fields[i].name)        }            // pools[0].end();        // exitProcess()    })        mysql_con.end();        exitProcess()}
查看完整描述

4 回答

?
繁花不似錦

TA貢獻1851條經驗 獲得超4個贊

await 明顯不是這樣用的。

await function1

而不是 
await function1(function (){
})

如果function1不是返回的Promise,那么你用await肯定沒效果


查看完整回答
反對 回復 2019-03-18
?
Cats萌萌

TA貢獻1805條經驗 獲得超9個贊

我使用了 bluebird 這個包


const bluebird = require('bluebird');


async function f(mysql_con){

    const query = bluebird.promisify(mysql_con.query.bind(mysql_con));

    const result1 = await query('XXX');

    const result2 = await query('XXX');

    console.log(result1,result2)

}


查看完整回答
反對 回復 2019-03-18
?
慕運維8079593

TA貢獻1876條經驗 獲得超5個贊

你這個顯然不能用async+await,要先promise化,你這個現在是用回調的形式


查看完整回答
反對 回復 2019-03-18
  • 4 回答
  • 0 關注
  • 530 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號