0

読み取り、書き込み、および別の読み取りの 3 つの操作があります。各操作は、SAVEPOINT を使用して開始されたトランザクション内にあります。値を読み取り、それを読み取るために使用したトランザクションを中止し、値を設定し、それを設定するために使用したトランザクションをコミットし、後で中止するトランザクションで再度読み取ります。データベースを再度開くと、セットが元に戻されます。

次のシェルスクリプトで問題を切り分けました。

$ 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

私は何が欠けていますか?

4

1 に答える 1

0

ドキュメントから:

単純な ROLLBACK コマンド (TO キーワードなし) とは異なり、ROLLBACK TO コマンドはトランザクションをキャンセルしないことに注意してください。

だから、私はRELEASEそれぞれの後に実行する必要がありますROLLBACK TO

于 2015-02-02T22:02:20.163 に答える