亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

mysql 大表批量刪除大量數據的實現方法

瀏覽:3日期:2023-10-05 18:09:01

問題參考自:https://www.zhihu.com/question/440066129/answer/1685329456 ,mysql中,一張表里有3億數據,未分表,其中一個字段是企業類型,企業類型是一般企業和個體戶,個體戶的數據量差不多占50%,根據條件把個體戶的行都刪掉。請問如何操作?答案為個人原創

假設表的引擎是 Innodb, MySQL 5.7+

刪除一條記錄,首先鎖住這條記錄,數據原有的被廢棄,記錄頭發生變化,主要是打上了刪除標記。也就是原有的數據 deleted_flag 變成 1,代表數據被刪除。但是數據沒有被清空,在新一行數據大小小于這一行的時候,可能會占用這一行。這樣其實就是存儲碎片。

之后,相關數據的索引需要更新,清除這些數據。并且,會產生對應的 binlog 與 redolog 日志。如果 delete 的數據是大量的數據,則會:

如果不加 limit 則會由于需要更新大量數據,從而索引失效變成全掃描導致鎖表,同時由于修改大量的索引,產生大量的日志,導致這個更新會有很長時間,鎖表鎖很長時間,期間這個表無法處理線上業務。 由于產生了大量 binlog 導致主從同步壓力變大 由于標記刪除產生了大量的存儲碎片。由于 MySQL 是按頁加載數據,這些存儲碎片不僅大量增加了隨機讀取的次數,并且讓頁命中率降低,導致頁交換增多。 由于產生了大量日志,我們可以看到這張表的占用空間大大增高。解決方案

我們很容易想到,在 delete 后加上 limit 限制控制其數量,這個數量讓他會走索引,從而不會鎖整個表。

但是,存儲碎片,主從同步,占用空間的問題并沒有解決。可以在刪除完成后,通過如下語句,重建表:

alter table 你的表 engine=InnoDB, ALGORITHM=INPLACE, LOCK=NONE;

注意這句話其實就是重建你的表,雖然你的表的引擎已經是 innodb 了,加上后面的, ALGORITHM=INPLACE, LOCK=NONE 可以不用鎖表就重建表。

還有一種方案是,新建一張同樣結構的表,在原有表上加上觸發器:

create trigger person_trigger_update AFTER UPDATE on 原有表 for each row begin set @x = 'trigger UPDATE';Replace into 新表 SELECT * from 原有表 where 新表.id = 原有表.id;END IF;end;

這樣可以保證線上業務有新數據會同步。之后,將所有企業類型的數據,插入新表,同時如果已存在則證明發生了更新同步就不插入。個體戶數據由于業務變化,并不在這個表上更新,所以這樣通過了無表鎖同步實現了大表的數據清理

到此這篇關于mysql 大表批量刪除大量數據的實現方法的文章就介紹到這了,更多相關mysql 大表批量刪除內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 欧美5g影院天天爽天天看 | 国产伦一区二区三区高清 | 成年人黄色片网站 | 深夜做爰性大片中文 | 国产午夜在线观看视频 | 一级黄色免费大片 | 成年人免费网站在线观看 | japanesefree夫妇互换 | 欧美黄色大片免费看 | 黄色网页观看 | 99毛片 | 欧美一级片网址 | 欧美一级日韩一级 | 快射视频在线观看 | 国产专区在线视频 | 国产精品入口麻豆免费看 | 美国一级黄色片 | 小蝌蚪在线成人免费视频 | 国产精品麻豆va在线播放 | 国产成人福利在线视老湿机 | 成本人h片3d动漫网站在线看 | 国产91福利 | 欧美日韩性生活 | 成人爽爽激情在线观看 | 黄色欧美 | 国产大片免费观看网站 | 欧美日韩国产人成在线观看 | 182tv成人午夜在线观看 | 国产精品国产精品 | 日韩欧美在线观看视频一区二区 | 亚洲 自拍 欧美 另类小说 | 特黄色 | 黄色a三级三级三级免费看 黄色a三级免费看 | 国产手机在线观看视频 | 日韩亚洲欧美一区二区三区 | 三级黄色免费网站 | 亚洲成人aaa | 粉嫩jk制服美女啪啪 | 亚洲爽视频| 在线国产毛片 | 可以免费看黄的网址 |