0

我目前正在使用 NodeJS v10.24.0,并且在将 MySQL 查找设置为与 ExpressJS 异步时遇到了一些麻烦。

主要的:

    app.get('/player/:username', async function (req, res) {

        var uuid = await sqlMgr.lookupName(req.params.username, db, dbConf.prefix)
        if (!uuid) {
            res.status(404).send("Player not found");
        } else {
            res.redirect('/uuid/' + uuid);
        }

    })

sqlMgr.lookupName:

async function lookupName(username, db, prefix) {
    const sql = "SELECT `uuid` FROM `" + prefix + "players` WHERE `playerName` = '" + username + "';";

    db.query(sql, function (err, rows) {
        if (err) {
            throw (err);
        }

        let uuid = rows[0].uuid;
        return uuid;
    })
}

我一直在纠结,并在任何可能的地方打了 await 和 async ,但页面只会呈现,并且 uuid 将在 MySQL 查找完成之前返回未定义。

4

0 回答 0