MySQL 清除表空間碎片

碎片產生的緣由mysql

(1)表的存儲會出現碎片化,每當刪除了一行內容,該段空間就會變爲空白、被留空,而在一段時間內的大量刪除操做,會使這種留空的空間變得比存儲列表內容所使用的空間更大;sql

(2)當執行插入操做時,MySQL會嘗試使用空白空間,但若是某個空白空間一直沒有被大小合適的數據佔用,仍然沒法將其完全佔用,就造成了碎片;性能

(3)當MySQL對數據進行掃描時,它掃描的對象實際是列表的容量需求上限,也就是數據被寫入的區域中處於峯值位置的部分;orm

例如:對象

一個表有1萬行,每行10字節,會佔用10萬字節存儲空間,執行刪除操做,只留一行,實際內容只剩下10字節,但MySQL在讀取時,仍看作是10萬字節的表進行處理,因此,碎片越多,就會愈來愈影響查詢性能。io

查看錶碎片大小table

(1)查看某個表的碎片大小form

mysql> SHOW TABLE STATUS LIKE '表名';select

結果中'Data_free'列的值就是碎片大小im

(2)列出全部已經產生碎片的表

mysql> select table_schema db, table_name, data_free, engine from information_schema.tables where table_schema not in ('information_schema', 'mysql') and data_free > 0;

清除表碎片

(1)MyISAM表

mysql> optimize table 表名

(2)InnoDB表

mysql> alter table 表名 engine=InnoDB

 

建議

清除碎片操做會暫時鎖表,數據量越大,耗費的時間越長,能夠作個腳本,定按期檢查mysql中 information_schema.TABLES字段,查看 DATA_FREE 字段,大於0話,就表示有碎片,例如每週三凌晨,檢查DATA_FREE字段,大於本身認爲的警惕值的話,就清理一次。

相關文章
相關標籤/搜索