中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

杭州市| 莱西市| 新乡市| 唐海县| 合山市| 万年县| 台东市| 柳州市| 久治县| 呼玛县| 台江县| 东源县| 同仁县| 富川| 南平市| 沐川县| 历史| 彰化市| 彩票| 泸州市| 新化县| 平武县| 额敏县| 措勤县| 富阳市| 孝感市| 永兴县| 乐都县| 潼南县| 南宁市| 江山市| 阿鲁科尔沁旗| 珲春市| 淮南市| 融水| 新野县| 天津市| 益阳市| 陵水| 凤台县| 万源市|