Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sqlite/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sqlite 为什么我的修改没有使用保存点写入磁盘?_Sqlite_Savepoints - Fatal编程技术网

Sqlite 为什么我的修改没有使用保存点写入磁盘?

Sqlite 为什么我的修改没有使用保存点写入磁盘?,sqlite,savepoints,Sqlite,Savepoints,我有三个操作,一个读操作、一个写操作和另一个读操作,每个操作都在使用保存点启动的事务中。我读取了一个值,中止了我用来读取它的事务,我设置了值,提交了我用来设置它的事务,然后在一个我后来中止的事务中再次读取它。当我再次打开数据库时,集合被撤消 我在以下shell脚本中隔离了我的问题: $ sqlite3 oi.sqlite3 <<<"CREATE TABLE test (value TEXT);" $ sqlite3 oi.sqlite3 <<<"INSERT

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

我在以下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;"

我缺少什么?

来自文档:

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


因此,我需要在每次
回滚到

后运行
RELEASE
,使用
BEGIN
COMMIT
,而不是像预期的那样使用保存点
1 # Read before set
0 # Read after set
1 # Read after reopening the database