从 SQLite 读取未提交的更改(脏读)

问题描述 投票:0回答:2

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

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

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

我做错了什么吗?这个编译指示不是应该使 sqlite3 客户端表现不同吗?

database sqlite isolation-level read-uncommitted dirtyread
2个回答
7
投票

我对自己回答:不,看来不可能。 read_uncommissed 隔离模式需要启用共享缓存,目前仅适用于同一进程中的不同线程。这似乎是研究这个的最佳地点:http://www.sqlite.org/sharedcache.html.


0
投票

根据我的实验,在 SQLite 中使用

READ UNCOMMITTED
SERIALIZABLE
(默认)不会出现以下所有异常。 *SQLite 没有
READ COMMITTED
REPEATABLE READ
:

异常 阅读未提交的内容 已提交阅读 可重复阅读 可序列化
脏读 没有 - - 没有
不可重复阅读 没有 - - 没有
幻读 没有 - - 没有
丢失更新 没有 - - 没有
写入倾斜 没有 - - 没有

*我为我的实验运行了以下命令:

PRAGMA read_uncommitted=true; -- READ UNCOMMITTED
PRAGMA read_uncommitted=false; -- SERIALIZABLE 
© www.soinside.com 2019 - 2024. All rights reserved.