File "addbooks.py", line 77, in saveBook
conn.commit()
sqlite3.OperationalError: cannot commit transaction - sql statements in progress
代码如下:
conn = sqlite3.connect(fname)
cread = conn.cursor()
cread.execute('''select book_text from table''')
while True:
row = cread.fetchone()
if row is None:
break
....
for entry in getEntries(doc):
saveBook(entry, conn)
无法执行fetchall(),因为表和列的大小很大,并且内存不足.
可以在不诉诸肮脏技巧的情况下做些什么(例如在内存中获取行标识,可能会合适,然后逐行选择行)?
解决方法:
问题是您已将连接保留为自动提交模式.在整个事务中包装一个事务,以便仅在完成所有更新之后才进行提交,并且应该都可以正常工作.