- 主页 > 生活百科 > >
MySQL 整体架构与 SQL 执行原理( 五 )
通过增加系统版本号 , 每次事务操作 , 会比较系统版本号 InnoDB为每行记录添加了一个版本号(系统版本号) , 每当修改数据时 , 版本号加一 。在读取事务开始时 , 系统会给事务一个当前版本号 , 事务会读取版本号<=当前版本号的数据 , 这时就算另一个事务插入一个数据 , 并立马提交 , 新插入这条数据的版本号会比读取事务的版本号高 , 因此读取事务读的数据还是不会变 。 MVCC 是什么? 基于CAS(Compare-and-swap) 有条件更新(Conditional Update) 通过undo log 来实现 原子性是事务的基本特性 , 保证了事务中的操作是不可拆分的整体 , 那么原子性是如何实现的呢?事务的原子性表现的两个方面: 通过redo log 来实现 事务提交失败 , 那么事务中的操作都失败 , 这个是通过数据库的撤销操作日志来保证的 , 也称之为undo log 。 事务提交成功保证事务中的操作都会完成 。1、是正确执行完事务 , 没有出现任何问题;2、是事务提交成功但是出异常 , 数据库恢复之后 , 提交完成的事务会保证数据库完成该事物的操作 。对于第一种正常情况不予讨论 , 因为不存在 异常情况 , 那么第2种实际上是和上文说的持久性是相关联的 , 而这个是基于重做日志(redo log)来保证提交完成的事务在异常情况下保证数据操作能够进行: 事务提交成功时 , 那么事务中的操作总会完成 事务提交失败 , 那么事务中的操作都失败 原子性 一致性 隔离性 Undo原理 与 Redo原理 和Undo Log相反 , Redo Log记录的是新数据的备份 。在事务提交前 , 只要将Redo Log持久化即可 , 不需要将数据持久化 。当系统崩溃时 , 虽然数据没有持久化 , 但是Redo Log已经持久化 。系统可以根据Redo Log的内容 , 将所有数据恢复到最新的状态 。 在操作任何数据之前 , 首先将数据备份到一个地方(这个存储数据备份的地方称为Undo Log) 。然后进行数据的修改 。如果出现了错误或者用户执行了ROLLBACK语句 , 系统可以利用Undo Log中的备份将数据恢复到事务开始之前的状态 。 Undo原理:(备份旧数据) Redo原理:(保存最新数据)
推荐阅读
-
新神榜|《新神榜:杨戬》票房大卖,不是自身进步大,全靠同行衬托
-
#cnBeta#Editor上线:Word文档编辑的智能助手,[图]Microsoft
-
环球时报-环球网|印尼新冠肺炎新增确诊病例1821例,累计突破14万例
-
-
-
古天乐|人到中年跑去动脸,古天乐怪、牛莉认不出,丑还影响演技,何必呢
-
-
梁山|要是梁山好汉没被招安,而是选择起义,他们能打到宋朝东京吗?
-
音乐是自己|适合吃的食物,改善肠胃,消除皱纹,预防血管疾病,女性到40岁
-
-
医学界风湿频道|等你“E”起参加!,风湿大咖MDT专场
-
纤美生活|个性升级轻松演绎优雅气质,街拍:褶皱设计增加了V领上衣的华丽感
-
产业气象站■差别竟然这么大?掌握这些知识,轻松买对手机,网购与实体店购买手机
-
你的生活是绝对不可能,只剩下丧这个字,世界处处都充满希望
-
『陈向东』跟谁学再遭香橼做空被指40%注册用户是虚构 陈向东:呵呵
-
-
董事长|成绩单!金陵饭店:2020年半年度净利润约31万元,同比下降99.13%
-
胃肠息肉患者术后依旧腹泻、腹胀?这些症状不消除,息肉难以去根
-
互联网信号|144Hz竞速屏+44W超快闪充,iQOO Neo3性能强悍,带来极致体验
-
第一次泡茶包的水要倒掉吗?茶包要一直泡还是拿出来?