zoukankan      html  css  js  c++  java
  • 第20课 管理事务处理

    第20课 管理事务处理

    20.1 事务处理

    使用事务处理(transaction processing),通过确保成批的SQL操作要么完全执行,要么完全不执行,来维护数据库的完整性。

    事务处理是一种机制,用来管理必须成批执行的SQL操作,保证数据库不包含不完整的操作结果。利用事务处理,可以保证一组操作不会中途停止,它们要么完全执行,要么完全不执行(除非明确指示)。如果没有错误发生,整组语句提交给(写到)数据库表;如果发生错误,则进行回退(撤销),将数据库恢复到某个已知且安全的状态。

    下面是关于事务处理需要知道的几个术语:

    • 事务(transaction)指一组SQL语句;
    • 回退(rollback)指撤销指定SQL语句的过程;
    • 提交(commit)指将未存储的SQL语句结果写入数据库表;
    • 保留点(savepoint)指事务处理中设置的临时占位符(placeholder),可以对它发布回退(与回退整个事务处理不同)。

    20.2 控制事务处理

    管理事务的关键在于将SQL语句组分解为逻辑块,并明确规定数据何时应该回退,何时不应该回退。

    MariaDB和MySQL中等同的代码为:

    START TRANSACTION
    ...
    

    Oracle使用的语法:

    SET TRANSACTION
    ...
    

    20.2.1 使用ROLLBACK

    SQL的ROLLBACK命令用来回退(撤销)SQL语句,请看下面的语句:

    DELETE FROM Orders;
    ROLLBACK;
    

    在事务处理块中,DELETE操作(与INSERT和UPDATE操作一样)并不是最终的结果。

    20.2.2 使用COMMIT

    进行明确的提交,使用COMMIT语句。

    为在Oracle中完成相同的工作,可如下进行:

    SET TRANSACTION
    DELETE OrderItems WHERE order_num = 12345;
    DELETE Orders WHERE order_num = 12345;
    COMMIT; 
    

    20.2.3 使用保留点

    使用简单的ROLLBACK和COMMIT语句,就可以写入或撤销整个事务。但是,只对简单的事务才能这样做,复杂的事务可能需要部分提交或回退。

    要支持回退部分事务,必须在事务处理块中的合适位置放置占位符。这样,如果需要回退,可以回退到某个占位符。

    在SQL中,这些占位符称为保留点。在MariaDB、MySQL和Oracle中创建占位符,可使用SAVEPOINT语句:

    SAVEPOINT delete1;
    

    每个保留点都要取能够标识它的唯一名字,以便在回退时,DBMS知道回退到何处。

    在MariaDB、MySQL和Oracle中,如下进行:

    ROLLBACK TO delete1;
    

    提示:保留点越多越好
    可以在SQL代码中设置任意多的保留点,越多越好。为什么呢?因为保留点越多,你就越能灵活地进行回退。

    20.3 小结

    我们学习了如何使用COMMIT和ROLLBACK语句对何时写数据、何时撤销进行明确的管理;还学习了如何使用保留点,更好地控制回退操作。

  • 相关阅读:
    求1+2+3+...+n
    孩子们的游戏(圆圈中最后剩下的数) 约瑟夫环
    扑克牌顺子
    翻转单词顺序列
    左旋转字符串
    和为S的两个数字
    和为S的连续正数序列
    CocoaPods 更新
    UITextView 动态高度计算(iOS7版)
    Mac 把图片反色
  • 原文地址:https://www.cnblogs.com/zhangsonghui/p/13347861.html
Copyright © 2011-2022 走看看