#-*-coding utf-8-*- # Общественное достояние, 2023, Алексей Безбородов (Alexei Bezborodov) import sqlite3 from bot_sys import log # Работа с базой данных # Имя файла БД g_bd_file_name = 'bot.db' def GetBDFileName(): return g_bd_file_name # --------------------------------------------------------- # Функции работы с базой # --------------------------------------------------------- def GetBDDateTimeNow(): return 'datetime(\'now\')' def SelectBDTemplate(a_Bot, a_TableName): def SelectBD(): return a_Bot.SQLRequest(f'SELECT * FROM {a_TableName}') return SelectBD def RequestsExecute(a_BDFileName, a_Commands): for cmd in a_Commands: SQLRequest(a_BDFileName, cmd, commit = True) def RequestSelectTemplate(a_BDFileName, a_TableName): def SelectBD(): return SQLRequest(a_BDFileName, f'SELECT * FROM {a_TableName}') return SelectBD def SQLRequest(a_BDFileName, a_Request : str, commit = False, return_error = False, param = None): db = sqlite3.connect(a_BDFileName) cursor = db.cursor() result = [] error = None try: if not param is None: cursor.execute(a_Request, (param)) else: cursor.execute(a_Request) result = cursor.fetchall() if commit: db.commit() except sqlite3.Error as e: log.Error(f'Ошибка при обработке запроса [{a_Request}]:{str(e)}') error = "Ошибка sqlite3:" + str(e) cursor.close() db.close() if not error and commit: log.Success(f'Выполнен запрос [{a_Request}]') if return_error: return result, error return result