为什么我的修改不是使用SAVEPOINT写入磁盘的?

时间:2015-02-02 20:10:47

标签: sqlite savepoints

我有三个操作,一个是读,一个是写,另一个是读操作,每个操作都在使用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

我错过了什么?

1 个答案:

答案 0 :(得分:0)

来自文档:

  

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

因此,我需要在每个RELEASE之后运行ROLLBACK TO