zoukankan      html  css  js  c++  java
  • “事务”的个人理解,特性

    事务:就是一系列的动作,这些动作要么一起完成,要么都不完成。

    举例1:转账500,A账户扣钱500,B账户增加500,两个操作,如果其中一个没有完成,那么的话,要么500块凭空消失,要么无缘无故多了500。这显然是错误的。

    举例2:购买书籍,书籍只剩下1本,A跟B几乎同时购买书籍,但是A比B稍微快一点点,那么A会发出update语句,书籍数目减1变为0,且成功购买书籍,同时B也发出update语句,书籍减1变为-1,此时因为没有事务控制,所以两者都成功更新书籍数目,显然这是不正常的,所以需要事务控制。

    事务的四个特性:

    • 原子性:操作这些指令时,要么全部执行成功,要么全部不执行。只要其中一个指令执行失败,所有的指令都执行失败,数据进行回滚,回到执行指令前的数据状态。
    • 一致性:事务的执行使数据从一个状态转换为另一个状态,但是对于整个数据的完整性保持稳定。
    • 隔离性:在该事务执行的过程中,无论发生的任何数据的改变都应该只存在于该事务之中,对外界不存在任何影响。只有在事务确定正确提交之后,才会显示该事务对数据的改变。其他事务才能获取到这些改变后的数据。
    • 持久性:当事务正确完成后,它对于数据的改变是永久性的。 
  • 相关阅读:
    Vim的行号、语法显示等设置,即.vimrc文件的配置
    Vim 配置详解
    经典SQL语句大全
    几种流行的AJAX框架jQuery,Mootools,Dojo,Ext JS的对比
    GHOST XP SP3无法安装IIS服务的解决方法
    开发中巧用Enum枚举类型
    代码的坏味道
    C#转义字符
    Dijit、ExtJS、jQuery UI 异同浅析
    未雨绸缪 Plan to Throw One Away
  • 原文地址:https://www.cnblogs.com/convict/p/9902428.html
Copyright © 2011-2022 走看看