@VizerViper

Ошибка SQLite3 python: "sqlite3.OperationalError: near "logindata": syntax error" что делать?

import sqlite3

with sqlite3.connect("data.db") as db:
    cursor = db.cursor()

cursor.execute("""CREATE TABLE IF NOT EXISTS logindata(
    id integer PRIMARY KEY,
    name text,
    surname text,
    login text,
    password blob)""")

m = input("mode 1 reg 2 log 3 look ")

match m:
    case "1":
        name = input("name: ")
        surname = input("surname: ")
        login = input("login: ")
        password = input("password: ")
        cursor.execute(f"""INSERT INTO logindata(name, surname, login, password)
         VALUES(?, ?, ?, ?)""", (name, surname, login, password))
        db.commit()
    case "2":
        login = input("login: ")
        password = input("password: ")
        cursor.execute(f"SELECT * FROM logindata WHERE login = '{login}'")
        cf = cursor.fetchall()
        if cf:
            if cf[0][4] == password:
                print(f"Hi, {cf[0][1]} {cf[0][2]}!")
                m = input("Select mode:\n1) Quit\n2) Edit password\n3) Delete account\n")
                match m:
                    case "1":
                        print("ok")
                    case "2":
                        oldpass = input("Write old password\n")
                        if oldpass == cf[0][4]:
                            newpass = input("Write new password\n")
                            cursor.execute(f"UPDATE logindata SET password = '{newpass}' WHERE id={cf[0][0]}")
                            db.commit()
                        else:
                            print("Invalid password!")
                    case "3":
                        cursor.execute(f"DELETE logindata WHERE id={cf[0][0]}")
                        db.commit()
                    case _:
                        print("Invalid mode!")

            else:
                print("Invalid password!")
        else:
            print("Invalid login!")
    case "3":
        cursor.execute("SELECT * FROM logindata ORDER BY id")
        for x in cursor.fetchall():
            print(x)
db.close()

Ошибку выдает когда выбираю функцию удаления аккаунта (строка  45). Пробовал переписывать заново название таблицы, и во всех остальных частях всё работает.
  • Вопрос задан
  • 90 просмотров
Пригласить эксперта
Ответы на вопрос 1
phaggi
@phaggi Куратор тега Python
лужу, паяю, ЭВМы починяю
delete from mytable where id=1
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы