原子性和一致性的区别是什么?
注:
重度参考了:https://www.zhihu.com/question/30272728/answer/72476703(讲的非常好,逻辑清晰)
轻度参考了:https://www.cnblogs.com/fjdingsd/p/5273008.html(概念也比较清晰,只不过没有对比着这两个特性讲)
概念
原子性:一个事务内的操作,要么同时成功,要么同时失败
一致性:一个事务必须使数据库从一个一致性状态变换到另一个一致性状态
对于一致性,知乎链接中内容如下:

从这段话的理解来看,所谓一致性,即,从实际的业务逻辑上来说,最终结果是对的、是跟程序员的所期望的结果完全符合的
重点
一致性是基础,也是最终目的,其他三个特性(原子性、隔离性和持久性)都是为了保证一致性的
在比较简单的场景(没有高并发)下,可能会发生一些数据库崩溃等情况,这个时候,依赖于对日志的 REDO/UNDO 操作就可以保证一致性
而在比较复杂的场景(有高并发)下,可能会有很多事务并行的执行,这个时候,就很可能导致最终的结果无法保证一致性,比如(内容来自知乎链接):

即,这个时候,原子性不能保证一致性。因为从单个事务的角度看,不管是事务 1 还是事务 2,它们都保证的原子性(单个事务内的所有操作全部成功了),但最终,它们并没有保证数据库的一致性(因为从逻辑上说,账户 A 应该增加了 200 元,而不是 100 元)
所以,为了保证并发情况下的一致性,又引入了隔离性的概念
隔离性:即事务之间感知不到彼此的存在,就好像只存在本身一个事务一样
而对于怎样实现隔离性,又涉及到了乐观锁和悲观锁的概念(这两个概念还不大懂)
小小引申:
不考虑隔离性的时候,可能导致脏读、幻读和不可重复读的问题(这些问题,其实就是导致无法保证一致性的几种情况)
而隔离级别的概念,就是为了解决上述三个问题
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
2021-02-20 查看Navicat已保存数据库密码
2021-02-20 is not allowed to connect to this mysql server
2021-02-20 error while loading shared libraries: libstdc++.so.6: cannot open shared obj
2021-02-20 查看当前进程
2021-02-20 linux 通过服务名称查找目录
2021-02-20 在linux下登录MySQL,发现无法输入密码?