从SQLite数据库中读取未提交的更改

时间:2011-09-10 09:55:32

标签: database sqlite isolation-level

我编写了一个应用程序(在C ++中使用Qt),它将数据插入到SQLite数据库中。另一个应用程序从同一个数据库中读取数据,但我注意到无法读取未提交的数据。相反,我希望能够读取数据,即使它尚未提交。

阅读SQLite文档我发现pragma read_uncommitted,根据我的理解,应该是我需要的。问题是,即使我将其设置为true,我也无法获得未提交的数据。

我尝试运行执行插入过程的应用程序,同时启动sqlite3客户端。我将pragma设置为true,并尝试计算表中的记录。我得到的总是0(数据库在我的插入过程开始之前是空的),直到整个过程结束,我立即得到整个数据。

我做错了吗?是不是这个pragma应该让sqlite3客户端表现不同?

1 个答案:

答案 0 :(得分:5)

我回答自己:不,似乎不可能。 read_uncommitted隔离模式需要启用共享缓存,目前只能用于生活在同一进程中的不同线程。这似乎是研究这个问题的最佳场所:http://www.sqlite.org/sharedcache.html