【问题标题】:Why arent my modifications being written to the disk using SAVEPOINT?为什么我的修改没有使用 SAVEPOINT 写入磁盘?
【发布时间】:2015-02-02 20:10:46
【问题描述】:

我有三个操作,一个读、一个写和另一个读,每个操作都在一个使用 SAVEPOINT 启动的事务中。我读取了一个值,中止了我用来读取它的事务,我设置了该值,提交了我用来设置它的事务,然后我再次读取它,在我后来中止的事务中。当我再次打开我的数据库时,设置已撤消。

我在以下 shell 脚本中隔离了我的问题:

$ sqlite3 oi.sqlite3 <<<"CREATE TABLE test (value TEXT);"
$ sqlite3 oi.sqlite3 <<<"INSERT INTO test VALUES (1);"
$ sqlite3 oi.sqlite3 <<<"
 SAVEPOINT '1';
 RELEASE '1';
 SAVEPOINT '2';
 SELECT * FROM test;
 ROLLBACK TO '2';
 SAVEPOINT '3';
 UPDATE test SET value=0;
 RELEASE '3';
 SAVEPOINT '4';
 SELECT * FROM test;
 ROLLBACK TO '4';"
$ sqlite3 oi.sqlite3 <<<"SELECT * FROM test;"

我的输出是

1 # Read before set
0 # Read after set
1 # Read after reopening the database

我错过了什么?

【问题讨论】:

  • 使用 BEGINCOMMIT 代替 SAVEPOINT 按预期工作

标签: sqlite savepoints


【解决方案1】:

来自文档:

请注意,与普通的 ROLLBACK 命令(没有 TO 关键字)不同,ROLLBACK TO 命令不会取消事务。

所以,我需要在每个ROLLBACK TO 之后运行RELEASE

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2020-04-16
    • 2017-10-26
    • 2010-09-28
    • 2016-01-12
    • 1970-01-01
    • 1970-01-01
    • 2013-06-21
    • 2012-01-31
    相关资源
    最近更新 更多