Как мне «ОТКАТИТЬСЯ ДО» «ТОЧКИ СОХРАНЕНИЯ»?Python

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Как мне «ОТКАТИТЬСЯ ДО» «ТОЧКИ СОХРАНЕНИЯ»?

Сообщение Anonymous »

Я вставляю массив данных в базу данных SQLite, но иногда некоторые строки выдают исключение IntegrityError. При откате все предыдущие строки также удаляются. Я хочу вернуться к предыдущему состоянию и продолжить следующую вставку.

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

import sqlalchemy as alc

def insert(self, specs):
#do stuff to transfor specs in data_db

entry = Check_Point(data_db)
session.add(entry)

try:
session.flush()

except alc.exc.IntegrityError:
print 'int Error'
session.rollback()
Я нашел это.

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

for record in records:
try:
with session.begin_nested():
session.merge(record)
except:
print "Skipped record %s" % record
session.commit()
Я не могу заставить его работать, если записи представляют собой массив объектов (экземпляры Check_Point):
Транзакция этой сессии была отменена вложенным вызовомrollback(). Чтобы начать новую транзакцию, сначала выполните Session.rollback()


Подробнее здесь: https://stackoverflow.com/questions/130 ... -savepoint
Реклама
Ответить Пред. темаСлед. тема

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

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

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

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

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

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