zoukankan      html  css  js  c++  java
  • 原子性和一致性的区别是什么?

     
     
    注:
    重度参考了:https://www.zhihu.com/question/30272728/answer/72476703(讲的非常好,逻辑清晰)
    轻度参考了:https://www.cnblogs.com/fjdingsd/p/5273008.html(概念也比较清晰,只不过没有对比着这两个特性讲)
     
    概念
    原子性:一个事务内的操作,要么同时成功,要么同时失败
    一致性:一个事务必须使数据库从一个一致性状态变换到另一个一致性状态
     
    对于一致性,知乎链接中内容如下:
    从这段话的理解来看,所谓一致性,即,从实际的业务逻辑上来说,最终结果是对的、是跟程序员的所期望的结果完全符合的
     
    重点
    一致性是基础,也是最终目的,其他三个特性(原子性、隔离性和持久性)都是为了保证一致性的
    在比较简单的场景(没有高并发)下,可能会发生一些数据库崩溃等情况,这个时候,依赖于对日志的 REDO/UNDO 操作就可以保证一致性
    而在比较复杂的场景(有高并发)下,可能会有很多事务并行的执行,这个时候,就很可能导致最终的结果无法保证一致性,比如(内容来自知乎链接):
    即,这个时候,原子性不能保证一致性。因为从单个事务的角度看,不管是事务 1 还是事务 2,它们都保证的原子性(单个事务内的所有操作全部成功了),但最终,它们并没有保证数据库的一致性(因为从逻辑上说,账户 A 应该增加了 200 元,而不是 100 元)
    所以,为了保证并发情况下的一致性,又引入了隔离性的概念
     
    隔离性:即事务之间感知不到彼此的存在,就好像只存在本身一个事务一样
    而对于怎样实现隔离性,又涉及到了乐观锁和悲观锁的概念(这两个概念还不大懂)
     
    小小引申:
    不考虑隔离性的时候,可能导致脏读、幻读和不可重复读的问题(这些问题,其实就是导致无法保证一致性的几种情况)
    而隔离级别的概念,就是为了解决上述三个问题
     
     
  • 相关阅读:
    DataTable不能通过已删除的行访问该行的信息解决方法
    datatable删除行之datatable.Rows[i].Delete()。标记之后行没有了
    js判断字符串是否在数组中
    发布webservice之后调用不通
    实体类配置xml相关属性排序问题、json前后台交互
    Java堆和栈的区别 经典总结
    Java IO
    XSL 简明教程 (下)
    XSL 简 明 教 程(上)
    跟我学XSL
  • 原文地址:https://www.cnblogs.com/stone94/p/10409669.html
Copyright © 2011-2022 走看看