2024年9月26日: PostgreSQL 17 发布!
支持的版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:devel
不支持的版本: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

SAVEPOINT

SAVEPOINT — 在当前事务中定义一个新的保存点

概要

SAVEPOINT savepoint_name

描述

SAVEPOINT 在当前事务中建立一个新的保存点。

保存点是事务内部的一个特殊标记,允许回滚在建立保存点后执行的所有命令,将事务状态恢复到保存点时的状态。

参数

savepoint_name

赋予新保存点的名称。如果已存在具有相同名称的保存点,则在释放较新的同名保存点之前,它们将无法访问。

备注

使用 ROLLBACK TO 回滚到保存点。使用 RELEASE SAVEPOINT 销毁保存点,保留在建立保存点后执行的命令的效果。

保存点只能在事务块内建立。在一个事务中可以定义多个保存点。

示例

建立一个保存点,并在以后撤消在建立保存点后执行的所有命令的效果

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。

使用单个保存点名称

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

    -- rollback to the second savepoint
    ROLLBACK TO SAVEPOINT my_savepoint;
    SELECT * FROM table1;               -- shows rows 1 and 2

    -- release the second savepoint
    RELEASE SAVEPOINT my_savepoint;

    -- rollback to the first savepoint
    ROLLBACK TO SAVEPOINT my_savepoint;
    SELECT * FROM table1;               -- shows only row 1
COMMIT;

上述事务显示首先回滚行 3,然后回滚行 2。

兼容性

SQL 要求在建立另一个具有相同名称的保存点时自动销毁保存点。在 PostgreSQL 中,旧的保存点会被保留,尽管在回滚或释放时只会使用最新的保存点。(使用 RELEASE SAVEPOINT 释放较新的保存点会导致较旧的保存点再次可供 ROLLBACK TO SAVEPOINTRELEASE SAVEPOINT 使用。)否则,SAVEPOINT 完全符合 SQL 标准。

提交更正

如果您在文档中发现任何不正确的内容,与您对特定功能的体验不符,或者需要进一步说明,请使用 此表单 报告文档问题。