gpt4 book ai didi

Javascript 如何在 mysql 中使用 Async/Await

转载 作者:行者123 更新时间:2023-12-02 02:04:35 26 4
gpt4 key购买 nike

我正在尝试使用 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函数在实际返回之前就解析了呢?难道不应该等待返回吗?

感谢您的帮助

最佳答案

由于 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]
}

关于Javascript 如何在 mysql 中使用 Async/Await,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68613650/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com