首页 > 解决方案 > Discord.NET Kick Command

问题描述

So I have a bot I'm working on for a computer science project, and my kick command isn't working. I've tried commenting out the update SQL and the ReplyAsync lines but it just won't kick the user. Am I using the wrong datatype for the user?

public class Kick : ModuleBase<SocketCommandContext>
    {
        OleDbConnection con;
        OleDbDataAdapter da;

        [Command("kick")]
        [RequireUserPermission(GuildPermission.KickMembers)]
        [RequireBotPermission(GuildPermission.KickMembers)]
        public async Task KickUser(IGuildUser user, string reason = "No reason provided")
        {
            con = new OleDbConnection();
            con.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=BotDB.accdb";
            da = new OleDbDataAdapter();

            con.Open();
            da.InsertCommand = new OleDbCommand($"UPDATE UserData SET NumKick = NumKick + 1 WHERE UserID = '{Convert.ToString(user.Id)}'");
            da.InsertCommand.ExecuteNonQuery();
            con.Close();

            await ReplyAsync($"{user.Nickname} was kicked from the server for '{reason}'");
            await user.KickAsync(reason);
        }
    }

标签: c#sqlms-accessdiscorddiscord.net

解决方案


我设法修复它,由于字符串原因,我不得不删除默认值,并且在 InsertCommand 区域中,我忘记在 SQL 之后声明 OleDbConnection。


推荐阅读