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

相关推荐
尤物程序猿3 分钟前
spring的监听器的几种使用方式
java·数据库·spring
老华带你飞4 分钟前
学生请假管理|基于springboot 学生请假管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端·spring
一 乐23 分钟前
校务管理|基于springboot + vueOA校务管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·spring
太行山有西瓜汁1 小时前
达梦DTS工具:批量导出与导入DDL脚本完整指南
运维·服务器·数据库
无盐海1 小时前
Redis 哨兵模式
数据库·redis·缓存
APItesterCris1 小时前
高并发场景下的挑战:1688 商品 API 的流量控制、缓存策略与异步处理方案
大数据·开发语言·数据库·缓存
·云扬·1 小时前
InnoDB锁监控与排查:从基础到实战
数据库·oracle
代码扳手1 小时前
Go 微服务数据库实现全解析:读写分离、缓存防护与生产级优化实战
数据库·后端·go
shoubepatien1 小时前
JavaWeb_Web基础
java·开发语言·前端·数据库·intellij-idea
多云的夏天2 小时前
SpringBoot3+Vue3基础框架(1)-springboot+对接数据库表登录
数据库·spring boot·后端