SAVEPOINT

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

概要

SAVEPOINT savepoint_name

描述

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

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

参数

savepoint_name 新保存点的名称。

注解

使用[ROLLBACK TO SAVEPOINT](ROLLBACK_TO_SAVEPOINT.html#topic1)回滚到保存点。 使用[RELEASE SAVEPOINT](RELEASE_SAVEPOINT.html#topic1)销毁一个保存点,并在建立保存点后保持命令执行的效果。

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

示例

要建立一个保存点,然后撤消建立保存点后执行的所有命令的效果:

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要求自动删除一个保存点。 在Greenplum数据库中,保留了旧的保存点,尽管在回滚或释放时仅使用较新的保存点。 (释放较新的保存点将使较旧的保存点再次可用于[ROLLBACK TO SAVEPOINT](ROLLBACK_TO_SAVEPOINT.html#topic1)[RELEASE SAVEPOINT](RELEASE_SAVEPOINT.html#topic1)。) 否则,SAVEPOINT完全符合SQL。

另见

[BEGIN](BEGIN.html#topic1) , [COMMIT](COMMIT.html#topic1) , [ROLLBACK](ROLLBACK.html#topic1) , [RELEASE SAVEPOINT](RELEASE_SAVEPOINT.html#topic1) , [ROLLBACK TO SAVEPOINT](ROLLBACK_TO_SAVEPOINT.html#topic1)

Parent topic: SQL Command Reference

当前内容版权归GreenPlum和翻译组所有,若有侵权请联系删除下架 修订时间: 2024-09-15 21:48:11

results matching ""

    No results matching ""