• 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

  • 相关阅读:
    C++ - 类型转换 - static_cast - reinterpret_cast - const_cast - dynamic_cast
    算法通关村|黄金挑战|K个一组进行反转
    约瑟夫环问题
    循环神经网络——上篇【深度学习】【PyTorch】【d2l】
    在阿里做前端程序员,我是这样规划的
    Kmeans算法实现目标客户聚类分析
    Shell脚本-变量的定义、赋值和删除
    hibernate源码(1)--- schema创建
    jdk的bin目录下的工具
    Nautlius Chain主网正式上线,模块Layer3时代正式开启
  • 原文地址:https://blog.csdn.net/cozil/article/details/133690896