时间:2021-07-01 10:21:17 帮助过:4人阅读
联系上文SQL查询语句的执行
查询语句的那一套流程,更新语句也是同样会走一遍。
更新流程还涉及两个重要的日志模块:
? redo log(重做日志)和 binlog(归档日志)
redo log是InnoDB引擎特有的日志
WAL技术,全称是Write-Ahead Logging
它的关键点就是先写日志,再写磁盘。
具体来说,当有一条记录需要更新的时候,InnoDB引擎就会先把记录写到redo log里,并更新内存,此时更新就算完成了。
同时,InnoDB引擎会在适当的时候,将这个操作记录更新到磁盘里面,而这个更新往往是在系统比较空闲的时候做。
write pos是当前记录的位置,一边写一边后移,写到末尾再从头开始。
checkpoint是当前要擦除的位置,擦除记录前要把记录更新到数据文件。
InnoDB就可以保证即使数据库发生异常重启,之前提交的记录都不会丢失,这个能力称为crash-safe。
Server层也有自己的日志,称为binlog(归档日志)
两种日志的区别
prepare和commit,这就是"两阶段提交"。主要是用来保证一致性
1.prepare阶段,记录修改到redo log
2.真正的提交commit需要binlog成功之后。
3.如果binlog未开始或者不完整,事务会回滚。
SQL更新语句的执行
标签:poi check 成功 html 数据文件 系统 重启 操作 blog