欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql 大表批量刪除大量數(shù)據(jù)的實(shí)現(xiàn)方法

 更新時(shí)間:2021年02月06日 14:39:57   作者:干貨滿滿張哈希  
這篇文章主要介紹了mysql 大表批量刪除大量數(shù)據(jù)的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

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

假設(shè)表的引擎是 Innodb, MySQL 5.7+

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

之后,相關(guān)數(shù)據(jù)的索引需要更新,清除這些數(shù)據(jù)。并且,會(huì)產(chǎn)生對(duì)應(yīng)的 binlog 與 redolog 日志。
如果 delete 的數(shù)據(jù)是大量的數(shù)據(jù),則會(huì):

  • 如果不加 limit 則會(huì)由于需要更新大量數(shù)據(jù),從而索引失效變成全掃描導(dǎo)致鎖表,同時(shí)由于修改大量的索引,產(chǎn)生大量的日志,導(dǎo)致這個(gè)更新會(huì)有很長(zhǎng)時(shí)間,鎖表鎖很長(zhǎng)時(shí)間,期間這個(gè)表無法處理線上業(yè)務(wù)。
  • 由于產(chǎn)生了大量 binlog 導(dǎo)致主從同步壓力變大
  • 由于標(biāo)記刪除產(chǎn)生了大量的存儲(chǔ)碎片。由于 MySQL 是按頁加載數(shù)據(jù),這些存儲(chǔ)碎片不僅大量增加了隨機(jī)讀取的次數(shù),并且讓頁命中率降低,導(dǎo)致頁交換增多。
  • 由于產(chǎn)生了大量日志,我們可以看到這張表的占用空間大大增高。

解決方案

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

但是,存儲(chǔ)碎片,主從同步,占用空間的問題并沒有解決??梢栽趧h除完成后,通過如下語句,重建表:

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

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

還有一種方案是,新建一張同樣結(jié)構(gòu)的表,在原有表上加上觸發(fā)器:

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;

這樣可以保證線上業(yè)務(wù)有新數(shù)據(jù)會(huì)同步。之后,將所有企業(yè)類型的數(shù)據(jù),插入新表,同時(shí)如果已存在則證明發(fā)生了更新同步就不插入。個(gè)體戶數(shù)據(jù)由于業(yè)務(wù)變化,并不在這個(gè)表上更新,所以這樣通過了無表鎖同步實(shí)現(xiàn)了大表的數(shù)據(jù)清理

到此這篇關(guān)于mysql 大表批量刪除大量數(shù)據(jù)的實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)mysql 大表批量刪除內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql清空表數(shù)據(jù)的兩種方式和區(qū)別解析

    mysql清空表數(shù)據(jù)的兩種方式和區(qū)別解析

    這篇文章主要介紹了mysql清空表數(shù)據(jù)的兩種方式和區(qū)別,本文通過文字實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • MySQL 線上日志庫遷移實(shí)例

    MySQL 線上日志庫遷移實(shí)例

    這篇文章主要介紹了MySQL 線上日志庫遷移實(shí)例,幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下
    2021-03-03
  • MySQL中的字符替換示例詳解

    MySQL中的字符替換示例詳解

    本文介紹了 MySQL 中的兩種字符替換函數(shù):REPLACE 和 REGEXP_REPLACE,通過這兩個(gè)函數(shù)的使用,我們可以方便地進(jìn)行字符替換操作,提高數(shù)據(jù)處理的效率和準(zhǔn)確性,感興趣的朋友跟隨小編一起看看吧
    2023-06-06
  • 你的like語句為什么沒索引詳解

    你的like語句為什么沒索引詳解

    這篇文章主要給大家介紹了關(guān)于你的like語句為什么沒索引的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-10-10
  • DROP TABLE在不同數(shù)據(jù)庫中的寫法整理

    DROP TABLE在不同數(shù)據(jù)庫中的寫法整理

    這篇文章主要介紹了DROP TABLE在不同數(shù)據(jù)庫中的寫法整理的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • MySQL中登錄與退出超全圖文講解

    MySQL中登錄與退出超全圖文講解

    大多數(shù)人都認(rèn)為在不需要事務(wù)化處理的情況下,MySQL是管理內(nèi)容最好的選擇,下面這篇文章主要給大家介紹了關(guān)于MySQL中登錄與退出圖文講解的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • 配置MySQL與卸載MySQL實(shí)例操作

    配置MySQL與卸載MySQL實(shí)例操作

    我們主要介紹的是正確通過rpm包安裝、對(duì)MySQL進(jìn)行配置與卸載的實(shí)際操作步驟,以下就是文章的具體內(nèi)容描述,望你會(huì)有所收獲。
    2010-08-08
  • 在ubuntu中重置mysql服務(wù)器root密碼的方法

    在ubuntu中重置mysql服務(wù)器root密碼的方法

    在ubuntu下安裝了mysql 5 server,結(jié)果不知道什么原因,安裝時(shí)輸入的root帳號(hào)密碼在使用時(shí)無論如何都不能通過數(shù)據(jù)庫服務(wù)器的驗(yàn)證。無奈只有重置mysql的root帳號(hào)密碼。查了一下,用了以下方法成功的重置了root帳號(hào)密碼
    2012-10-10
  • MySQL時(shí)間差8小時(shí)的解決方案

    MySQL時(shí)間差8小時(shí)的解決方案

    本文介紹了在開發(fā)中遇到的時(shí)間問題,包括MySQL時(shí)間與系統(tǒng)時(shí)間不符、JDBC連接時(shí)區(qū)設(shè)置以及使用Jackson時(shí)可能出現(xiàn)的JSON時(shí)區(qū)問題,重點(diǎn)講解了如何修改MySQL時(shí)區(qū)、設(shè)置JDBC連接參數(shù)和調(diào)整JSON日期格式的時(shí)區(qū),需要的朋友可以參考下
    2024-07-07
  • Mysql單表訪問方法圖文示例詳解

    Mysql單表訪問方法圖文示例詳解

    這篇文章主要為大家介紹了Mysql單表訪問方法圖文示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07

最新評(píng)論