您好,登錄后才能下訂單哦!
這篇文章主要講解了“MySQL修改大表工具pt-online-schema-change的原理”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“MySQL修改大表工具pt-online-schema-change的原理”吧!
MySQL修改大表工具pt-online-schema-change的使用限制:
1)、如果修改表有外鍵,除非使用 --alter-foreign-keys-method 指定特定的值,否則工具不予執行
2)、被修改表必須要有主鍵,否則報錯:Cannot chunk the original table `houyi`.`ga`: There is no good index and the table is oversized. at ./pt-online-schema-change line 5353.
3)、被修改表上不能有針對after delete|insert|update三個觸發器,否則修改表結構操作失敗
MySQL修改大表工具pt-online-schema-change原理:
1)、首先使用帳號密碼連接到mysql后,獲取指定表的狀態信息,檢查是否有觸發器,檢查表是否有主鍵。
2)、接著按照修改表的表定義,新建一個名為'_tb_new'不可見的臨時表,對這個表執行alter添加字段,并校驗是否執行成功。
3)、然后針對源表創建三個觸發器,分別如下:
create trigger db_tb_del after delete on db.tb for each row delete ignore from db._tb_new where db._tb_new.id <=> OLD.id #刪掉新表中db._tb_new.id <=> OLD.id的數據,否則忽略操作
create trigger db_tb_del after update on db.tb for each row replace into db._tb_new(id,...) values(new.id,...) #源表執行update的時候,把對應的數據replace into的方式寫入新表
create trigger db_tb_del after insert on db.tb for each row replace into db._tb_new(id,...) values(new.id,...) #源表執行insert操作的時候,把對應的數據replace into的方式寫入新表
4)、觸發器創建好之后會執行insert low_priority ignore into db._tb_new(id,..) select id,... from tb lock in share mode語句復制源表數據到新表。
5)、復制完成之后執行語句:rename table db.tb to db._tb_old,db._tb_new to db.tb同時把源表修改為_tb_old格式,把新表_tb_new修改為源表名字的原子修改。
6)、接著,如果沒有加不刪除old表的選項,那么就會刪除Old表,然后刪除三個觸發器。到這里就完成了在線表結構的修改 。整個過程只在rename表的時間會鎖一下表,其他時候不鎖表。
感謝各位的閱讀,以上就是“MySQL修改大表工具pt-online-schema-change的原理”的內容了,經過本文的學習后,相信大家對MySQL修改大表工具pt-online-schema-change的原理這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。