时间:2021-07-01 10:21:17 帮助过:18人阅读
红色字体部分是重点,但是看得有些迷糊,还是动手测试下。
根据《mysqldump的几个主要选项探究》的介绍,我们备份执行的命令mysqldump --single-transaction --master-data相当于执行下面代码:
FLUSH TABLES; FLUSH TABLES WITH READ LOCK; SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ; START TRANSACTION WITH CONSISTENT SNAPSHOT; SHOW MASTER STATUS; UNLOCK TABLES; SHOW TABLES LIKE ‘xxx‘ SET OPTION SQL_QUOTE_SHOW_CREATE=1 SHWO CREATE TABLE ‘xxx‘ SHOW FIELDS FROM ‘xxx‘ SHOW TABLE STATUS LIKE ‘xxx‘ SELECT /*!40001 SQL_NO_CACHE */ * FROM xxx QUIT
场景1:mysqldump开始但尚未备份到表tb001时,另外回话对表tb001进行alter操作,然后mysqldump对表tb001进行导出
alter操作顺利完成,但是mysqldump操作失败。
场景2:mysqldump开始备份并完成tb001的导出,在对其他表进行导出过程中,其他回话对表进行alter操作
alter table操作被阻塞直至mysqldump完成或失败后退出。
##========================================================================##
总结:
single-transaction参数通过Innodb的多版本来获得数据一致性,而ALTER TABLE, DROP TABLE, RENAME TABLE,TRUNCATE TABLE等操作会破坏数据一致性,两种操作不能并发执行。
如果修改表操作在 ”mysqldump开启后但还未导出修改表数据前“ 的时间段内开始,则修改表操作成功完成,而mysqldump会执行失败;
如果修改表操作在 “mysqldum已导出修改表数据但还未结束mysqldump操作前”的时间段内开始,则修改表操作被阻塞,mysqldum能成功完成,在mysqldump操作完成后修改表操作方可正常执行。
##========================================================================##
MySQL--当mysqldump --single-transaction遇到alter table
标签:数据 UI tomat png evel ble img master targe