91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL修改大表工具pt-online-schema-change的原理

發布時間:2021-08-31 23:34:12 來源:億速云 閱讀:210 作者:chen 欄目:MySQL數據庫

這篇文章主要講解了“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的原理這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

连江县| 辉县市| 昌黎县| 天柱县| 谢通门县| 突泉县| 沁水县| 商都县| 黄龙县| 平顶山市| 长宁区| 利辛县| 太白县| 靖安县| 固原市| 乌拉特后旗| 南投县| 克山县| 美姑县| 山阴县| 安仁县| 广安市| 旬邑县| 礼泉县| 额尔古纳市| 新余市| 湖口县| 鸡西市| 丰镇市| 车险| 涞水县| 林周县| 遂宁市| 蕲春县| 嵊泗县| 鄂伦春自治旗| 莲花县| 乌鲁木齐市| 昌平区| 明光市| 宜兰县|