首頁  >  問答  >  主體

解決SQL查詢中匯出一個值時的回呼地獄問題

<p>我的目標是,如果我的SQL查詢找到結果,將<code>someVar</code>設定為1。 問題是,賦值是局部的,當我嘗試使用<code>console.log(someVar)</code>時,在區塊內結果為1,但在區塊外結果為0。有沒有辦法將值匯出到區塊外? </p> <pre class="brush:js;toolbar:false;">let someVar = 0; con.query(`SOME SQL QUERY`, (error, rows) => { if (error) throw error if (rows.length > 0) { someVar = 1; //console.log(someVar) -> 結果為1 } }); con.end(); //console.log(someVar) -> 結果為0 if (someVar === 0) { // Some code } </pre></p>
P粉014218124P粉014218124412 天前435

全部回覆(1)我來回復

  • P粉545218185

    P粉5452181852023-09-05 18:56:24

    感謝Fredrik,我修復了它。 我最終使用瞭如下的promise

    let promiseQuery = await new Promise((resolve, reject) => {
        con.query(`SOME SQL QUERY`, (error, results, fields) => {
            if (error) reject(error);
            resolve(results || {});
        })
    
    })
    const someVar = promiseQuery.length
    if (someVar === 0) {
        // Some code
    } else {
        // Some code
    }

    回覆
    0
  • 取消回覆