Javascript 如何在 mysql 中使用 Async/Await

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

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 函数在它实际返回一些东西之前解析呢?难道不应该等待回报吗?

感谢您的帮助

okam6hz 回答:Javascript 如何在 mysql 中使用 Async/Await

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]
    });
,

由于 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,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]
}
本文链接:https://www.f2er.com/827.html

大家都在问