170 похожих чатов

Учусь работать с sqlite, подскажите, как можно улучшить этот код,

и как избавиться от постоянных self.dbConnect.commit(). Нужны ли они вообще?

class SQLite3:
def __init__(self, path: str) -> None:
dbConnect = sqlite3.connect(path)
self.cursor = dbConnect.cursor()

def createTable(self, table_name: str, **kwargs):
if kwargs:
kwargs = ', '.join([f'{k} {v}' for k, v in kwargs.items()])
self.cursor.execute(f"""CREATE TABLE IF NOT EXISTS {table_name} ({kwargs})""")

def dropTable(self, table_name: str):
self.cursor.execute(f"""DROP TABLE IF EXISTS {table_name}""")
self.dbConnect.commit()

#-------------------------------------------------ALTER-------------------------------------------------#
def alterRenameTo(self, table_name: str, new_table_name: str):
self.cursor.execute(f"""ALTER TABLE {table_name} RENAME TO {new_table_name}""")
self.dbConnect.commit()

def alterRenameColumn(self, table_name: str, column_name: str, new_column_name: str):
self.cursor.execute(f"""ALTER TABLE {table_name} RENAME COLUMN {column_name} TO {new_column_name}""")
self.dbConnect.commit()

def alterAddColumn(self, table_name: str, column_name: str, args: tuple):
self.cursor.execute(f"""ALTER TABLE {table_name} ADD COLUMN {column_name} {' '.join(args)}""")
self.dbConnect.commit()

def alterDropColumn(self, table_name: str, column_name: str):
self.cursor.execute(f"""ALTER TABLE {table_name} DROP COLUMN {column_name}""")
self.dbConnect.commit()
#-------------------------------------------------ALTER-------------------------------------------------#

3 ответов

14 просмотров

нужны, но не тут

https://t.me/ru_python_beginners/1888242

Избавься сначала от f строк в запросе

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

Обсуждают сегодня

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
31
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Всем привет, подскажите/посоветуйте пожалуйста. Фаердак компоненты, имею одно место где бизнес хочет видеть при открытии формы список всех клиентов, это порядка 30к. Мои дово...
Sasha Sch
14
Здравствуйте. Задача состоит в том, чтобы сделать real-time чат в мобильном приложении. После передачи сообщения пользователем через веб-сокеты, для основного и долговременног...
🐾
5
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
8
Книга Юрова В.И пойдёт для обучения?
Botsman
24
Всем доброго дня, ребят подскажите пожалуйста, если в курсе по ассемблеру используется MASM32, могу ли я использовать FASM? В чем явная разница и будет ли у меня все работать?
Botsman
17
Где можно найти примеры эффективного "асинхронного" tcp сервера на C? Я видел select, kqueue, poll, epoll и т.д. Ввод-вывод неблокирующий, но обработка клиентов блокирующая
#
10
Hi Everyone! To all Are you Looking for Interview Support at the Lowest Price? Look no further! Then contact us 👉We offer Interview Support :-for a low cost variety of tech...
Rambabu Nallamilli
3
Карта сайта