Mysql三大日志
(1)bin log日志是用在主从复制场景下,跟事务没有什么关系
将master数据库的增删改SQL语句以二进制的形式记录到bin log日志里面,然后将这个binlog日志发送给slave数据库,slave数据库执行binlog日志中的增删改sql语句来达到和master数据库数据一致
(2)undo log和redo log
①undo log里面存的是数据被修改之前的数据,redo log存的是数据被修改之后的数据
执行undo log会回滚到事务执行前的数据,可以保证原子性
当数据库宕机了,数据库执行redo log可以将数据恢复到事务执行后的版本,可以保证持久性
②undo log是逻辑日志(针对的是每一行的记录),存储的是数据修改的逆操作(如果执行了一条 UPDATE 语句将某个字段的值从 10 修改为 15,那么 Undo Log 中就会记录一个相应的逆操作,将这个字段的值从 15 修改回 10。但不是完整的sql语句)redo log是物理日志(针对的是整个物理页),磁盘中哪一页的哪个数据被改成什么了
能不能用redo log替代bin log?
不能,因为(1)bin log是满了会再起一个新的bin log文件,redo log满了会覆盖之前的redo log文章来源:https://www.toymoban.com/news/detail-696689.html
(2)bin log是逻辑日志,redo log是物理日志,记录的是哪个数据页的哪个数据被改成什么了,在不同的机器上数据的位置是不一样的,可能在这个机器上是在这个数据页上,在另一台机器,就是在另一个数据页上文章来源地址https://www.toymoban.com/news/detail-696689.html
到了这里,关于mysql三大日志 undolog,redolog,undolog的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!