Usando o salvingpoints no python sqlite3
-
19-09-2019 - |
Pergunta
Estou tentando usar o SavePoints com o módulo SQLITE3 incorporado no Python 2.6. Toda vez que tento liberar ou reverter um salvamento, sempre recebo um OperationalError: no such savepoint
. o que estou perdendo?
python version: 2.6.4 (r264:75821M, Oct 27 2009, 19:48:32)
[GCC 4.0.1 (Apple Inc. build 5493)]
PySQLite version: 2.4.1
sqlite3 version: 3.6.11
Traceback (most recent call last):
File "spDemo.py", line 21, in <module>
conn.execute("release savepoint spTest;")
sqlite3.OperationalError: no such savepoint: spTest
A partir deste código:
import sys
import sqlite3
print 'python version:', sys.version
print 'PySQLite version:', sqlite3.version
print 'sqlite3 version:', sqlite3.sqlite_version
print
conn = sqlite3.connect('db_spDemo.db')
conn.isolation_level = "DEFERRED"
with conn:
conn.execute("create table example (A, B);")
with conn:
conn.execute("insert into example values (?, ?);", (0,200))
conn.execute("savepoint spTest;")
conn.execute("insert into example values (?, ?);", (1,201))
conn.execute("insert into example values (?, ?);", (2,202))
conn.execute("release savepoint spTest;")
conn.execute("insert into example values (?, ?);", (5,205))
Solução
Isso parece ser o resultado de como o módulo SQLITE3 se comporta com esse nível de isolamento.
Isso funciona, observe as duas mudanças:
import sys
import sqlite3
print 'python version:', sys.version
print 'PySQLite version:', sqlite3.version
print 'sqlite3 version:', sqlite3.sqlite_version
print
conn = sqlite3.connect('shane.sqlite')
conn.isolation_level = None # CHANGED
with conn:
conn.execute("create table example (A, B);")
with conn:
conn.execute("insert into example values (?, ?);", (0,200))
conn.execute("savepoint spTest;")
conn.execute("insert into example values (?, ?);", (1,201))
conn.execute("insert into example values (?, ?);", (2,202))
conn.execute("rollback to savepoint spTest;") # CHANGED
conn.execute("insert into example values (?, ?);", (5,205))
Resultado:
$ python shane-sqlite3.py && sqlite3 shane.sqlite 'select * from example;' python version: 2.6.2 (release26-maint, Apr 19 2009, 01:56:41) [GCC 4.3.3] PySQLite version: 2.4.1 sqlite3 version: 3.6.10 0|200 5|205
Esta é uma resposta insatisfatória e não vi nada relevante nos documentos do módulo SQLITE3 (nem tentei dar uma olhada na fonte). Mas espero que isso ajude você a encontrar a direção certa.
Outras dicas
Este é um bug no pysqlite, veja o rastreador de problemas Pysql e o rastreador de problemas python.
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow