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
(2)bin log是逻辑日志,redo log是物理日志,记录的是哪个数据页的哪个数据被改成什么了,在不同的机器上数据的位置是不一样的,可能在这个机器上是在这个数据页上,在另一台机器,就是在另一个数据页上