VastbaseE100

基于开源技术的HTAP数据库管理系统。性能优异,稳定可靠,提供诸多专属领域特性。

Menu

SAVEPOINT

SAVEPOINT - 在当前事务中定义新的保存点

语法格式

SAVEPOINT savepoint_name

说明

SAVEPOINT 在当前事务中 Build 新的保存点。

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

参数说明

  • savepoint_name

    要提供给新保存点的名称。

注意事项

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

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

示例

要 Build 保存点,然后撤消 Build 后执行的所有命令的效果:

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要求在 Build 另一个具有相同名称的保存点时自动销毁保存点。在Vastbase E100中,保留旧保存点,但在回滚或释放时只使用最新的保存点。 (使用RELEASE SAVEPOINT 释放较新的保存点将导致旧的保存点再次被 ROLLBACK TO SAVEPOINT 和 RELEASE SAVEPOINT 访问。)否则, SAVEPOINT 完全符合SQL。