【问题标题】:Javascript How to use Async/Await with a mysqlJavascript 如何在 mysql 中使用 Async/Await
【发布时间】:2021-10-07 08:07:03
【问题描述】:

我正在尝试使用 Async/Await 查询我的 mysql 数据库的值,但我的常量“映射”总是返回未定义,我不太清楚为什么

const get_map = () =>{
    db.query('SELECT game,game2 FROM battles WHERE player1=? OR player2=?',[result.char,result.char],(err,results)=>{
        if(err){
            return(err)
        }
        if(!results[0]){
            return('No such battle?')
        }
        console.log(results[0])
        return(results[0])
    })
}
const proccessTurn = async ()=>{
    const map = await get_map()
    console.log(map)
    let game = JSON.parse(map.game)
    let game2 = JSON.parse(map.game2)
    const char = result.char
    const playerTurn = game2.turn[0]
}

控制台甚至不记录

console.log(results[0])

这一行那么为什么 await 函数在它实际返回之前解析呢?不应该等回报吗?

感谢您的帮助

【问题讨论】:

  • get_map 中删除{...} 或将其更改为return db.query(...),它应该可以正常工作。
  • @ulou 问题是什么,您的建议如何解决?
  • 问题是他忘了return,我觉得这个解释已经够好了。

标签: javascript mysql node.js asynchronous async-await


【解决方案1】:

由于 mysql 库不支持 Promise,您可以像这样使用 Node.js 中的 promisify util 函数:

const { promisify } = require('util');

const query = promisify(db.query).bind(db);

const get_map = async () => {
    try {
         const result = await query('SELECT game,game2 FROM battles WHERE player1=? OR player2=?',[result.char,result.char]);
         if(!results[0]){
             return 'No such battle?';
         }
         console.log(results[0])
         return results[0];
    }
    catch(e) {
         return e;
    }
}
const proccessTurn = async ()=>{
    const map = await get_map()
    console.log(map)
    let game = JSON.parse(map.game)
    let game2 = JSON.parse(map.game2)
    const char = result.char
    const playerTurn = game2.turn[0]
}

【讨论】:

  • 嗨,我试过了,但它返回 TypeError: Cannot read property 'typeCast' of undefined
  • 这是我的代码中的一个错误,我将.bind(db.query) 替换为.bind(db)。您应该使用此代码,而不是像其他答案建议的那样重新发明轮子。
  • @GuerricP 我认为,返回一个新的承诺并不是重新发明轮子。通过创建一个新的 Promise,您可以在同一个函数中处理您的业务特定的边缘情况。
  • 返回一个promise并不是重新发明轮子,返回一个promise 用我们自己的代码是。 Node.js 回调签名是标准,Promise 是标准,这就是 promisify 存在的原因。
  • @rauf543 从历史上看,Node.js 使用带有三个参数的回调来处理异步:errordatanext。当前的趋势是使用 Promise,这有助于编写更简洁的代码,尤其是 async/await,因此他们提供了一个原生工具:promisify,以便于迁移到新的 Promise 模式。它只需要一个函数,该函数将 Node.js 回调作为最后一个参数,并将其转换为返回 Promise 的函数。不建议使用自定义代码包装到 Promise,因为存在此内置解决方案。
【解决方案2】:

db.query() 的第三个参数是回调。如果您在回调中返回任何内容,它实际上会返回到函数本身(在这种情况下为 db.query)。你没有从get_map() 返回任何东西。所以像这样从 get_map 返回一个新的承诺,

const get_map = () =>{
    return new Promise((resolve, reject) => {
        db.query('SELECT game,game2 FROM battles WHERE player1=? OR player2=?',[result.char,result.char],(err,results)=>{
            if(err){
                reject(err)
            }
            if(!results[0]){
                reject('No such battle?')
            }
            console.log(results[0])
            resolve(results[0])
        }
    });
}
const proccessTurn = async ()=>{
    const map = await get_map()
    console.log(map)
    let game = JSON.parse(map.game)
    let game2 = JSON.parse(map.game2)
    const char = result.char
    const playerTurn = game2.turn[0]
    });

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-05-13
    • 2022-11-18
    • 2019-01-29
    • 1970-01-01
    • 2019-07-20
    • 2021-10-10
    相关资源
    最近更新 更多