当前位置: 首页 > 知识库问答 >
问题:

nodejsmysqlpromise返回未定义的

施德运
2023-03-14

我正在尝试为discord bot执行命令,它从MySQL表中输出整数。

我尝试使用async/await、Promissions和回调来实现这一点,但结果总是一样的。在这里,我用promise再次尝试,因为在过去它不知何故起了作用。现在不会了。

下面是返回promise的函数:

exports.checkAccess = (user) => {
    return new Promise((resolve,reject) => {
        sql.condb.query("SELECT `accessLevel` FROM `users` WHERE `DiscordID` = '" + user + "' LIMIT 1", function(err,rows){
            if(err) reject(err);
            else resolve(rows);
        })
    });
}

下面的代码将结果赋值给Access Level变量:

let accessLevel = -1;
cmds.checkAccess(message.author.id).then(rows=>{
        accessLevel = rows[0].accessLevel;
    }).catch((err)=>{
        console.log(err);
});

Catch函数捕获表示“TypeError:无法读取未定义的属性“accessLevel”的错误。

共有1个答案

端木野
2023-03-14

您的查询似乎不会返回任何结果,而不会返回未定义的promise。

我建议您将查询放入变量中,并使用console.log获取生成的查询,以便检查最终查询。

let query = "SELECT `accessLevel` FROM `users` WHERE `DiscordID` = '" + user + "' LIMIT 1";
console.log(query);

尝试在mysql编辑器中选择标准查询。

 类似资料:
  • 问题内容: 因此,当我打开灯箱时,我试图禁止在页面上滚动,而我发现这个确实有用的脚本非常有用。不幸的是,当我在自己的页面上使用它时,它也禁止在灯箱中滚动。我开始用警报调试代码,只是发现该事件。wheelDelta在我的页面上返回“undefined”,而在JSFiddle中,它返回-120。 问题答案: jQuery事件处理程序中的对象不能反映真实事件。是IE和Opera的非标准事件属性,可通过j

  • 我是JS的新手,不明白为什么我的程序中的图像没有改变。所有的变量都运行良好。下面是片段 所有的图像都被命名为1.jpg,2.jpg,3.jpg,4.jpg,直到24。这是一种很奇怪的方式,我也知道,如果有人知道更好的方式,那会更好。

  • 我在chrome控制台中写了这样的表达式: 它返回:

  • 我有下面的函数,它可以正确地从响应中提取图像的前缀和后缀,并生成一个可变的结果,其中包含场馆图像的url。然而,当我返回结果时,我一直没有定义。这里出了什么问题?

  • 我打印了错误, 这两个文件在同一个目录中

  • 问题内容: 我在这段代码上遇到问题;返回值返回为“ undefined”。有什么问题? 较新的代码: 我怎么称呼它: 问题答案: 根据您的修改进行更新 解决这些问题应可使代码正常工作。 旧答案 您正在以 同步 模式调用XMLHttpRequest ,这意味着它将 阻塞 脚本,直到请求完成为止,因为您是在阻塞调用之后(即请求已经完成之后)分配回调,因此您的代码永远不会收到通知。 由于同步模式会阻止脚