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问题
如何在Excel中读取公式并将其转换为Python中的计算?
1 回答
如何在excel中读取嵌入的excel,并将嵌入文件中的信息存储在主excel文件中?
9 回答
如何在Excel中返回未知列长度的非空顶行列值?
8 回答
如何在excel中选择数据列?
2 回答
如何在Excel中通过脚本自动为一列中的所有单元格创建公共别名
1 回答
如何在excel中高效格式化范围AttributeError:“tuple”对象没有属性“fill”
5 回答
如何在excel单元格中编写python函数
6 回答
如何在excel单元格中自动执行此python代码?
10 回答
如何在excel工作表中创建具有相应值的新列
5 回答
如何在Excel工作表中复制条件为单元格颜色的python数据框?
3 回答
如何在Excel工作表中循环
8 回答
如何在excel工作表中打印嵌套词典?
10 回答
如何在excel工作表中绘制所有类的继承树?
3 回答
如何在Excel工作表中自动调整列宽?
3 回答
如何在excel工作表中追加并进一步处理
3 回答
如何在excel工作表之间进行更改?
10 回答
如何在excel或csv上获取selenium数据?
4 回答
如何在Excel或Python中将正确的值赋给正确的列
10 回答
如何在excel或python中提取单词周围的文本?
3 回答
如何在excel或python中转换来自Jira的3w 1d 4h的fromat数据?
5 回答