首页  >  问答  >  正文

解决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 天前436

全部回复(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
  • 取消回复