Discord.py и SQL — Сравнение между 2 таблицами в одном файле базы данных

#python #sqlite #discord.py

Вопрос:

Итак, у меня есть два стола, Серверы и Страйки. В таблице Серверов у меня есть максимальное значение для ударов. Я хочу сравнить удары, наносимые пользователем, с максимальными ударами, указанными в таблице Серверов. Я попробовал это:

 @commands.command(name='strike', pass_ctx= True)
@commands.has_permissions(manage_messages=True)

async def strike(self, ctx, member : discord.Member):
    
    first_strike = 1
    
    
    cursor = await self.client.db.cursor()
    await cursor.execute(f"SELECT Strikes_Have FROM Strikes WHERE Guild_ID = {ctx.guild.id} AND User_ID = {member.id}")
    result = await cursor.fetchone()
    
    if result == None:
        
        cursor = await self.client.db.cursor()
            
        sql = f"INSERT INTO Strikes(Guild_ID, User_ID, Strikes_Have) VALUES({ctx.guild.id}, {member.id}, {first_strike})"
            
    
    else:
        
        cursor = await self.client.db.cursor()
            
        sql = f"UPDATE Strikes SET Strikes_Have = Strikes_Have   1 where Guild_ID = {ctx.guild.id} AND User_ID = {member.id}"
        
        if result["Strikes_Have"] == result["MAX_STRIKES"]:
            await ctx.message.channel.send(f"{member} has the max amount of stirkes specified by the server")
            
            
    await cursor.execute(sql)
    await self.client.db.commit()
    await cursor.close()
            
    await ctx.message.channel.send(f"Striked {member}")`
 

Но получил эту ошибку:

 Traceback (most recent call last):
  File "/home/pi/.local/lib/python3.7/site-packages/discord/ext/commands/core.py", line 85, in wrapped
    ret = await coro(*args, **kwargs)
  File "/home/pi/EndorCore/cogs/Mod.py", line 225, in strike
    if result["Strikes_Have"] == result["MAX_STRIKES"]:
IndexError: No item with that key
 

Ответ №1:

Сообщение об ошибке, которое вы получаете в данный момент, вызвано тем, что вы пытаетесь получить доступ к столбцу данных, которого нет в таблице «забастовки». Чтобы получить максимальное значение, вам нужно запросить эту таблицу и получить число, а затем сравнить их. Например:

 cursor.execute(f"SELECT Strikes_Have FROM Strikes WHERE Guild_ID = {ctx.guild.id} AND User_ID = {member.id}")
user_result = cursor.fetchone()

cursor.execute(f"SELECT MAX_STRIKES FROM Servers WHERE Guild_ID = {ctx.guild.id}")
server_result = cursor.fetchone()

if user_result["Strikes_Have"] == server_result['MAX_STRIKES']:
    print("User has max strikes")