Savepoints

语法

SAVEPOINT 名称

RELEASE SAVEPOINT 名称

ROLLBACK TRANSACTION TO SAVEPOINT 名称

Savepoints

与BEGIN和COMMIT类似的创建事务的方法,名称不要求唯一且可以嵌套使用。

可以用在BEGIN...COMMIT定义的事务内部或外部。当在外部时,最外层的savepoint相当于BEGIN DEFERRED TRANSACTION。

ROLLBACK TO命令将事务回滚到创建SAVEPOINT的位置。该命令不会撤销事务,只是回滚到特定的位置,在这之间的所有SAVEPOINTs都会被回滚。

RELEASE命令相当于COMMIT一个SAVEPOINT。该命令导致最新匹配名称的savepoint从事务堆栈中移除,使ROLLBACK TO命令无法回滚到特定的savepoint。当RELEASE一个最外围的savepoint时相当于执行COMMIT命令。直接执行COMMIT命令则相当于RELEASE所有savepoints并且COMMIT事务。

如果RELEASE指定的名称不存在,数据不会发生改变且返回错误。

注意一个内部事务可能通过RELEASE提交事务,但是随后仍能通过一个外部的事务ROLLBACK所有改变。 比如电源故障、程序崩溃或系统崩溃都将导致最外围的事务被回滚。只有最外围的事务commit之后数据才会写入磁盘。

使用RELEASE命令时需要思考的问题:

  • 一些人把RELEASE视作是对SAVEPOINT的COMMIT,这样想是没有问题的,但要注意RELEASE提交的数据仍然可能被外围的事务通过ROLLBACK命令回滚。

  • 另一个观点是RELEASE把当前命名的事务合并到了父级事务中变成了一个事务。

  • 你也可以认为savepoints是事务时间轴中的一个标记,SAVEPOINT创建新的标记,ROLLBACK TO则将时间轴倒回到那个标记所在时间,而RELEASE则是擦除时间轴上的标记,并且不对数据库做任何的修改。

嵌套规则

最后启动的事务将是提交或回滚时的第一个事务。

BEGIN命令只能用于事务堆栈为空的情况,也就是说BEGIN不能创建嵌套事务。

COMMIT命令提交所有未完成的事务并且清空事务堆栈。

RELEASE命令从最近添加到事务堆栈的保存点开始,并按时间向后释放保存点,直到它释放具有匹配保存点名称的保存点。之前的保存点,就算存在同名保存点,都不会受影响。如果该操作导致事务堆栈清空,则事务被真正提交。

ROLLBACK命令没有TO语句的情况下回滚所有修改并清空事务堆栈。

有TO语句时命令将事务回滚到具有匹配名称的最近的SAVEPOINT,但是在创建SAVEPOINT之后发生的所有数据库更改都将回滚。如果TO指定的名称不存在则该命令会报告一个错误。

原文链接:https://www.sqlite.org/lang_savepoint.html

相关推荐
泡沫·41 分钟前
5.MariaDB数据库管理
数据库·mariadb
i***512643 分钟前
【数据库】MySQL的安装与卸载
数据库·mysql·adb
数白1 小时前
Oracle 数据迁移最佳实践(不使用第三方工具)
数据库·oracle
周杰伦fans1 小时前
C# 中的**享元工厂**模式
开发语言·数据库·c#
空空kkk1 小时前
SpringMVC——拦截器
java·数据库·spring·拦截器
J***51682 小时前
MySql中的事务、MySql事务详解、MySql隔离级别
数据库·mysql·adb
SelectDB2 小时前
Apache Doris 中的 Data Trait:性能提速 2 倍的秘密武器
数据库·后端·apache
i***27952 小时前
Spring boot 3.3.1 官方文档 中文
java·数据库·spring boot
TDengine (老段)2 小时前
TDengine 日期函数 DATE 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
q***65692 小时前
PostgreSQL 中进行数据导入和导出
大数据·数据库·postgresql