他のバージョンの文書 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9.6 | 9.5 | 9.4 | 9.3 | 9.2 | 9.1 | 9.0 | 8.4 | 8.3 | 8.2 | 8.1 | 8.0 | 7.4 | 7.3 | 7.2

SAVEPOINT

名前

SAVEPOINT -- 現在のトランザクション内にセーブポイントを新規に定義

概要

SAVEPOINT savepoint_name

説明

SAVEPOINTは、現在のトランザクション内に新しいセーブポイントを確立します。

セーブポイントとはトランザクション内の特別な印で、確立後に実行されたコマンドを全てロールバックし、セーブポイントの時点の状態にトランザクションを戻すことができます。

パラメータ

savepoint_name

新しいセーブポイントに付与する名前です。

注釈

セーブポイントまでロールバックするにはROLLBACK TO SAVEPOINTを使用してください。 確立後に行われたコマンドの効果を保持したままセーブポイントを破棄するには、RELEASE SAVEPOINTを使用してください。

セーブポイントはトランザクションブロックの内側でのみ確立することができます。 1つのトランザクションの中で複数のセーブポイントを定義することができます。

セーブポイントを確立し、その後に確立後に実行した全てのコマンドの効果を取消します。

BEGIN;
    INSERT INTO table1 VALUES (1);
    SAVEPOINT my_savepoint;
    INSERT INTO table1 VALUES (2);
    ROLLBACK TO SAVEPOINT my_savepoint;
    INSERT INTO table1 VALUES (3);
COMMIT;

上のトランザクションでは、1と3は挿入されますが、2は挿入されません。

セーブポイントを確立し、その後に破棄します。

BEGIN;
    INSERT INTO table1 VALUES (3);
    SAVEPOINT my_savepoint;
    INSERT INTO table1 VALUES (4);
    RELEASE SAVEPOINT my_savepoint;
COMMIT;

上のトランザクションでは、3と4が挿入されます。

互換性

SQLでは、同じ名前のセーブポイントが確立したときに自動的にセーブポイントを破棄することを要求しています。 PostgreSQLでは、古いセーブポイントは保持されます。 しかし、ロールバックや解放時にはより最近のセーブポイントが使用されます。 (より新しいセーブポイントを解放することで、古い方が再びROLLBACK TO SAVEPOINTRELEASE SAVEPOINTから使用できるようになります。) この他についてはSAVEPOINTは完全にSQLに従います。

関連項目

BEGIN, COMMIT, RELEASE SAVEPOINT, ROLLBACK, ROLLBACK TO SAVEPOINT