Python中文
首页
教程
问答
标签
搜索
登录
注册
Python/SQLite3:无法提交-没有事务是acti
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我试图使用Python(传统的,2.7)和SQLite(3)来编写<a href="http://pastebin.com/YeBgbBAV" rel="nofollow noreferrer">book indexer</a>。</p> <p>代码可以归结为以下SQL语句序列:</p> <pre><code>'select count(*) from tag_dict' () /* [(30,)] */ 'select count(*) from file_meta' () /* [(63613,)] */ 'begin transaction' () 'select id from archive where name=?' ('158326-158457.zip',) /* [(20,)] */ 'select id from file where name=? and archive=?' ('158328.fb2', 20) /* [(122707,)] */ 'delete from file_meta where file=?' (122707,) 'commit transaction' () # error: cannot commit - no transaction is active </code></pre> <p>隔离级别是'DEFERRED'('EXCLUSIVE'没有更好的选择)。</p> <p>我试图使用connection.commit()而不是cursor.execute('commit')-没有发生任何有用的事情。</p> <ul> <li>当然,我已经搜索过stackoverflow和Net,但是找到的答案是不相关的。</li> <li>由于性能原因,自动提交模式不可接受。</li> <li>我一次使用唯一的数据库文件。</li> <li>我的代码是单线程运行的。</li> <li>所有的SQL执行都是通过一个函数完成的,这个函数确保我一次只打开一个游标。</li> </ul> <h2>那么,这里的交易怎么了?</h2> <p>如果我使用connection.commit()(注意:没有connection.begin方法!),那么我只是丢失了数据。</p> <p>当然,我已经对数据库文件及其目录的文件权限进行了double/triple/d检查。</p> <hr/> <p>好吧,我经常在提出问题后一分钟就找到了解决办法。</p> <p>作为一个新手,我有8个小时不能回答自己的问题。。。 所以,答案就在这里:</p> <p>解决方案是<a href="http://www.velocityreviews.com/forums/t326247-pysql-lite-transactions-question.html" rel="nofollow noreferrer">found here</a>,由唯一的想法组成:</p> <h2>不要在Python应用程序的非自动提交模式下使用BEGIN/COMMIT-仅使用db.COMMIT()和db.rollback()!</h2> <p>这听起来很奇怪,但确实有效。</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>这是一个相当晚的响应,但是如果您希望对事务进行更精细的控制,可以查看<a href="https://github.com/rogerbinns/apsw" rel="nofollow noreferrer">APSW</a>。我在pysqlite上运行了一些涉及读取的延迟事务测试,但它似乎没有正确执行。</p>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
jupyter运行一个旧的pytorch版本
3 回答
Jupyter运行不同版本的卸载库?
2 回答
Jupyter运行指定的键盘快捷键
5 回答
Jupyter通过.local文件“逃逸”virtualenv。我该如何缓解这种情况?
1 回答
Jupyter重新加载自定义样式
7 回答
Jupyter错误:“没有名为Jupyter_core.paths的模块”
9 回答
jupyter错误:无法在随机林中将决策树视为png
7 回答
Jupyter错误'内核似乎已经死亡,它将自动重新启动'为一个给定的代码块
8 回答
Jupyter错误地用阿拉伯语和字母数字元素显示Python列表
4 回答
Jupyter隐藏数据帧索引,但保留原始样式
6 回答
Jupyter集线器:启动器中出现致命错误。。。系统找不到指定的文件
10 回答
Jupyther中相同值的相同哈希,但导出到Bigquery时不相同
4 回答
Jupy上Python的读/写访问问题
2 回答
jupy上没有模块cv
6 回答
Jupy上的排序错误
1 回答
Jupy中bqplot图形的紧凑布局
6 回答
Jupy中matplotlib plot的连续更新
4 回答
Jupy中Numpy函数的文档
1 回答
Jupy中Pandas的自动完成问题
8 回答
jupy中Qt后端的Matplotlib动画
6 回答