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

MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因

 更新時間:2021年05月07日 17:18:22   作者:王文安  
這篇文章主要介紹了MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因,幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下

問題描述

在 MySQL 中使用 delete 語句刪除數(shù)據(jù)之后,監(jiān)控視圖中可用的磁盤空間沒有增加,磁盤使用率沒有下降等等。

解決方案

delete 不釋放空間是 MySQL 自身機(jī)制的原因,需要重建表才可以釋放磁盤空間,可以參考的操作:

  1. 執(zhí)行 optimize table ${table_name}。
  2. 如果是 InnoDB 的表,執(zhí)行 alter table ${table_name} engine = innodb。

需要注意以下兩個問題:

這兩個命令都會重建表,盡量不要在磁盤空間緊張(>90%)的時候進(jìn)行操作,先擴(kuò)容磁盤,操作完之后再縮容。
這兩個命令在開始和結(jié)束的時候都會嘗試獲取 metadata lock,所以盡量不要在業(yè)務(wù)高峰期執(zhí)行。

問題分析

在 MySQL 的機(jī)制中,delete 刪除的行只是被標(biāo)記為刪除狀態(tài),如果刪除的行很多,整個數(shù)據(jù)頁(innodb_page)的行都會被刪除的時候,數(shù)據(jù)頁也只會標(biāo)記為刪除,都不會真正的物理刪除,而是一直占用,等待被復(fù)用。

例如:

可以看到 delete 前后,data_length 并沒有發(fā)生變化,但是 data_free 增加了很多。這說明數(shù)據(jù)雖然刪了,但是并沒有被釋放,仍舊被 test1 表占用,只是顯示處于 free 狀態(tài),以后再寫入新數(shù)據(jù)的時候就可以直接復(fù)用,而不需要在申請新的磁盤空間了。

這個時候使用alter table test1 engine = innodb 看看效果:

可以看到 data_length 和 data_free 都變成了空表的狀態(tài),僅有一個 innodb_page (默認(rèn) 16k)。

PS:data_free 本身也可以用來評估表的空間碎片,當(dāng)這個數(shù)字非常高的時候,可以考慮用同樣的方法重建表,回收一部分磁盤空間。

以上就是MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因的詳細(xì)內(nèi)容,更多關(guān)于MySQL 刪數(shù)據(jù)后磁盤空間未釋放的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • MySQL中的批量修改、插入操作數(shù)據(jù)庫

    MySQL中的批量修改、插入操作數(shù)據(jù)庫

    在平常的項目中,我們會需要批量操作數(shù)據(jù)庫的時候,例如:批量修改,批量插入,那我們不應(yīng)該使用 for 循環(huán)去操作數(shù)據(jù)庫,這樣會導(dǎo)致我們反復(fù)與數(shù)據(jù)庫發(fā)生連接和斷開連接,影響性能和增加操作時間,所以可以使用SQL 批量修改的方式去操作數(shù)據(jù)庫,感興趣的朋友一起學(xué)習(xí)下吧
    2023-09-09
  • MySql學(xué)習(xí)day03:數(shù)據(jù)表之間的連接、查詢詳解

    MySql學(xué)習(xí)day03:數(shù)據(jù)表之間的連接、查詢詳解

    這篇文章主要介紹了MySql數(shù)據(jù)表之間的連接、查詢,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • MySQL中or用法及mybatis or用法詳解

    MySQL中or用法及mybatis or用法詳解

    在SQL查詢語句中,OR關(guān)鍵字用于連接兩個或多個條件,表示滿足其中一個條件即可,當(dāng)使用OR時,如果第一個條件為真,則不會檢查第二個條件;如果第一個條件為假,則會檢查第二個條件,這篇文章主要介紹了MySQL中or用法及mybatis or用法總結(jié),需要的朋友可以參考下
    2024-05-05
  • MySQL 有關(guān)MHA搭建與切換的幾個錯誤log匯總

    MySQL 有關(guān)MHA搭建與切換的幾個錯誤log匯總

    這篇文章主要介紹了MySQL 有關(guān)MHA搭建與切換的幾個錯誤log匯總,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下
    2020-12-12
  • MySQL索引類型Normal、Unique和Full Text的講解

    MySQL索引類型Normal、Unique和Full Text的講解

    今天小編就為大家分享一篇關(guān)于MySQL索引類型Normal、Unique和Full Text的講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • 在MySQL concat里面使用多個單引號,三引號的問題

    在MySQL concat里面使用多個單引號,三引號的問題

    今天小編就為大家分享一篇在MySQL concat里面使用多個單引號,三引號的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • 詳解MySQL的字段默認(rèn)null對唯一索引的影響

    詳解MySQL的字段默認(rèn)null對唯一索引的影響

    這篇文章主要為大家介紹了MySQL的字段默認(rèn)null對唯一索引的影響詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • MySQL日志設(shè)置及查看方法

    MySQL日志設(shè)置及查看方法

    這篇文章主要介紹了MySQL日志設(shè)置及查看方法,需要的朋友可以參考下
    2017-05-05
  • mysql通過find_in_set()函數(shù)實現(xiàn)where in()順序排序

    mysql通過find_in_set()函數(shù)實現(xiàn)where in()順序排序

    這篇文章主要介紹了mysql通過find_in_set()函數(shù)實現(xiàn)where in()順序排序的相關(guān)內(nèi)容,具有一定參考價值,需要的朋友可以了解下。
    2017-10-10
  • mysql8連接不上問題及解決

    mysql8連接不上問題及解決

    這篇文章主要介紹了mysql8連接不上問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08

最新評論