SAVEPOINT
SAVEPOINT¶
在当前事务中定义一个新的保存点。
- 语法
sql SAVEPOINT savepoint_name
- 描述
-
SAVEPOINT
在当前事务中建立一个新的保存点。保存点是事务内部的特殊标记,它允许回滚在建立事务后执行的所有命令,从而将事务状态恢复到保存点时的状态。
- 参数
-
该SQL命令参数说明见下
savepoint_name
- 新保存点的名称。
- 注解
-
使用
ROLLBACK TO SAVEPOINT
回滚到保存点。 使用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。
- 兼容性说明
- 建立另一个具有相同名称的保存点时,SQL要求自动删除一个保存点。在SeaboxMPP数据库中,保留了旧的保存点,尽管在回滚或释放时仅使用较新的保存点。(释放较新的保存点将使较旧的保存点再次可用于
ROLLBACK TO SAVEPOINT
和RELEASE SAVEPOINT
。)否则,SAVEPOINT
完全符合SQL。 - 相关SQL命令
BEGIN
,COMMIT
,ROLLBACK
,RELEASE SAVEPOINT
,ROLLBACK TO SAVEPOINT