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

防止discord bot崩溃(mysql)

宗政文彬
2023-03-14

我有一个discord bot,我正在处理一个命令,该命令从mysql数据库中显示关于一个字符的信息(通过提供字符名)。它工作得很好,但如果我提供了一个数据库中不存在的名称,如!characterinfo asdasfefcdce,则bot会崩溃。所以我的问题是如果我提供了一个错误的名称,如何防止它崩溃?。希望你能理解我的意思。

代码如下:

const Discord = require('discord.js');
const mysql = require('mysql');
const {stripIndents} = require("common-tags");
const { prefix, token } = require('../config.json');

module.exports.run = async (bot, message, args, connection3) => {

    if (message.content == '!characterinfo') {
        return message.reply('provide a character name!');
    }

    const name = args[0];

    connection3.query('SELECT * FROM characters WHERE name = ?', [name], function(err, results, rows) {
        if (err) throw err;

    const embed = new Discord.RichEmbed()
    .setColor('RANDOM')
    .setTitle('**Character Information**')
    .addField('Nickname:', results[0].name)
    .addField('Level:', results[0].level)
    .setFooter(`test`)

    .setTimestamp();

     message.channel.send(embed);
  });

}

module.exports.help = {
    name: "characterinfo",
}

如果你需要我提供你更多的信息,让我知道。

感谢任何帮助!

共有1个答案

庄阿苏
2023-03-14

机器人现在崩溃是因为在这一行

if (err) throw err;

您抛出了一个错误,以后不处理它,最简单的更改方法是用console.log或console.error替换throw

if (err) console.error(err);

或者您可以保留抛出并使用try/catch来包装代码。

try {
    connection3.query('SELECT * FROM characters WHERE name = ?', [name], function (err, results, rows) {
        if (err) throw err;

        const embed = new Discord.RichEmbed()
            .setColor('RANDOM')
            .setTitle('**Character Information**')
            .addField('Nickname:', results[0].name)
            .addField('Level:', results[0].level)
            .setFooter(`test`)
            .setTimestamp();

        message.channel.send(embed);
    });
} catch(err) {
    // Handle the error ...
    console.log(err)
}

编辑:所以当查询没有找到结果时,错误实际上是来自结果数组中没有任何条目,所以这个解决方案应该可以工作。

在做其他事情之前,您应该检查是否有“结果”。

try {
    connection3.query('SELECT * FROM characters WHERE name = ?', [name], function (err, results, rows) {
        if (err) throw err;
        if (!results[0]) return;

        const embed = new Discord.RichEmbed()
            .setColor('RANDOM')
            .setTitle('**Character Information**')
            .addField('Nickname:', results[0].name)
            .addField('Level:', results[0].level)
            .setFooter(`test`)
            .setTimestamp();

        message.channel.send(embed);
    });
} catch(err) {
    // Handle the error ...
    console.log(err)
}
 类似资料:
  • 问题内容: 我一直在开发一个Android应用程序,该应用程序经常使用以防止它崩溃,即使在不需要的地方也是如此。例如, 在视图与被引用,如: 在整个应用程序中都使用这种方法。堆栈跟踪没有打印出来,很难找到问题所在。该应用程序突然关闭而不打印任何堆栈跟踪。 我请我的长辈向我解释一下,他说: 这是为了防止生产崩溃。 我完全不同意 。对我来说,这不是防止应用程序崩溃的方法。它表明开发人员 不 知道自己在

  • 问题内容: 如果原始类未知,将导致崩溃。我已经看到再追从斯威夫特的早期历史这个问题的日期,使用Objective C语言所需的唯一解决方案(也预先日斯威夫特2的实现,,和)。我可以弄清楚Objective C的路线- 但如果可能的话,我宁愿理解仅Swift的解决方案。 例如- 数据已使用编码。如果编码数据的类别未知,则以下代码将失败。 我正在寻找一种Swift 2唯一的方法来尝试尝试之前测试数据是

  • 我让我的学长给我解释,他说, 这是为了防止生产中的崩溃。 我完全不同意。对我来说,这不是防止应用程序崩溃的方法。这表明开发人员不知道他/她在做什么,并有疑问。 由于这个问题得到了很多关注,有些人误解了这个问题(可能是因为我没有清楚地表达它),我打算重新表达它。 以下是开发人员在这里所做的 > 编写并测试一个函数,它可以是一个只是初始化视图的小函数,也可以是一个复杂的函数,测试后它被包裹在块中。即使

  • 问题内容: 尽管像这样 的元素通常会增长以适应其内容,但是使用float属性会给 CSS新手带来一个惊人的问题:如果浮动元素具有非浮动父元素,则父元素会折叠。 例如: 在此示例中,父div 不会扩展为包含其浮动的子级-似乎有height: 0。 你怎么解决这个问题? 我想在这里创建一个详尽的解决方案列表。如果您知道跨浏览器的兼容性问题,请指出。 解决方案1 Float the parent. 优点

  • 我是否缺少一些配置选项来防止它崩溃?通常情况下,所有异常都会被捕获并返回一个500错误,而服务器仍然处于活动状态。