Невозможно вставить строки в базу данных SQLite3 с Python даже после фиксацииPython

Программы на Python
Ответить
Anonymous
 Невозможно вставить строки в базу данных SQLite3 с Python даже после фиксации

Сообщение Anonymous »

Я пытаюсь вставить некоторые данные в базу данных SQLite. Я могу вставлять строки с помощью внешних приложений, но, делая это через Python, я не получаю... ничего. Никаких ошибок и новых строк. Если полезно, это работает как часть приложения Flask.
Я видел этот вопрос, хотя принятый ответ использует небезопасную интерполяцию строк.
Я зафиксировал свои изменения и использую именованные заполнители.
Вот моя функция для вставки строки:

Код: Выделить всё

def add_entry(item):
con = sqlite3.connect("db/service_requests.db")
cur = con.cursor()

item["submission_date"] = datetime.now().strftime('%d/%m/%y %H:%M:%S.%f')

cur.execute("INSERT INTO requests VALUES(NULL, :facility, :description, :quantity, :staged, :pickup_date, :delivery_date, :location, :submission_date, :priority, :comment)", item)
con.commit()
con.close()
return
Вот пример аргумента элемента:

Код: Выделить всё

 {'facility': 'Facility1',  'description': 'large boxes',  'quantity': '12', 'staged': 'Loose',  'pickup_date': '11/01/2024',  'delivery_date': '11/30/2024',  'location': 'Building A',  'priority': '1',  'comment': 'FRAGILE!',  'submission_date': '18/11/24 10:22:25.410386'}
И схема таблицы, представленная SQLite:

Код: Выделить всё

CREATE TABLE requests ( user TEXT, facility TEXT, description TEXT, quantity INTEGER, staged TEXT, pickup_date TEXT, delivery_date TEXT, location TEXT, submission_date TEXT, priority INTEGER, comment TEXT)


Подробнее здесь: https://stackoverflow.com/questions/792 ... committing
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»