Javascript 如何在 mysql 中使用 Async/Await
Posted
技术标签:
【中文标题】Javascript 如何在 mysql 中使用 Async/Await【英文标题】:Javascript How to use Async/Await with a mysql 【发布时间】: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
,我觉得这个解释已经够好了。
【参考方案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 使用带有三个参数的回调来处理异步:error
、data
和 next
。当前的趋势是使用 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]
);
【讨论】:
以上是关于Javascript 如何在 mysql 中使用 Async/Await的主要内容,如果未能解决你的问题,请参考以下文章
如何从 MySQL 数据库中获取数据并在 javascript 自动完成中使用?
如何使用 JavaScript 和 Node.js 将捕获的图像存储到 MySQL 数据库中
如果记录已经存在或者在 PDO MySQL 插入查询中不存在,如何生成 javascript 警报?