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

MySQL 清除表空間碎片的實(shí)例詳解

 更新時(shí)間:2017年10月19日 11:18:20   作者:徐劉根  
這篇文章主要介紹了MySQL 清除表空間碎片的實(shí)例詳解的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下

MySQL 清除表空間碎片的實(shí)例詳解

碎片產(chǎn)生的原因

(1)表的存儲(chǔ)會(huì)出現(xiàn)碎片化,每當(dāng)刪除了一行內(nèi)容,該段空間就會(huì)變?yōu)榭瞻?、被留空,而在一段時(shí)間內(nèi)的大量刪除操作,會(huì)使這種留空的空間變得比存儲(chǔ)列表內(nèi)容所使用的空間更大;

(2)當(dāng)執(zhí)行插入操作時(shí),MySQL會(huì)嘗試使用空白空間,但如果某個(gè)空白空間一直沒(méi)有被大小合適的數(shù)據(jù)占用,仍然無(wú)法將其徹底占用,就形成了碎片;

(3)當(dāng)MySQL對(duì)數(shù)據(jù)進(jìn)行掃描時(shí),它掃描的對(duì)象實(shí)際是列表的容量需求上限,也就是數(shù)據(jù)被寫入的區(qū)域中處于峰值位置的部分;

例如:

一個(gè)表有1萬(wàn)行,每行10字節(jié),會(huì)占用10萬(wàn)字節(jié)存儲(chǔ)空間,執(zhí)行刪除操作,只留一行,實(shí)際內(nèi)容只剩下10字節(jié),但MySQL在讀取時(shí),仍看做是10萬(wàn)字節(jié)的表進(jìn)行處理,所以,碎片越多,就會(huì)越來(lái)越影響查詢性能。

查看表碎片大小

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

mysql> SHOW TABLE STATUS LIKE '表名';

結(jié)果中'Data_free'列的值就是碎片大小

(2)列出所有已經(jīng)產(chǎn)生碎片的表

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

Engine不同,OPTIMIZE 的操作也不一樣的,MyISAM 因?yàn)樗饕蛿?shù)據(jù)是分開的,所以 OPTIMIZE 可以整理數(shù)據(jù)文件,并重排索引.

OPTIMIZE 操作會(huì)暫時(shí)鎖住表,而且數(shù)據(jù)量越大,耗費(fèi)的時(shí)間也越長(zhǎng),它畢竟不是簡(jiǎn)單查詢操作.所以把 Optimize 命令放在程序中是不妥當(dāng)?shù)?不管設(shè)置的命中率多低,當(dāng)訪問(wèn)量增大的時(shí)候,整體命中率也會(huì)上升,這樣肯定會(huì)對(duì)程序的運(yùn)行效率造成很大影響.比較好的方式就是做個(gè)shell,定期檢查mysql中 information_schema.TABLES字段,查看 DATA_FREE 字段,大于0話,就表示有碎片

建議

清除碎片操作會(huì)暫時(shí)鎖表,數(shù)據(jù)量越大,耗費(fèi)的時(shí)間越長(zhǎng),可以做個(gè)腳本,定期在訪問(wèn)低谷時(shí)間執(zhí)行,例如每周三凌晨,檢查DATA_FREE字段,大于自己認(rèn)為的警戒值的話,就清理一次。

如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

  • 詳解MySql存儲(chǔ)過(guò)程參數(shù)的入門使用

    詳解MySql存儲(chǔ)過(guò)程參數(shù)的入門使用

    這篇文章主要介紹了MySql存儲(chǔ)過(guò)程參數(shù)的入門使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • MySQL表的基本查詢操作大全(這一篇夠了)

    MySQL表的基本查詢操作大全(這一篇夠了)

    表的增刪查改,簡(jiǎn)稱表的?CURD?操作?:?Create(創(chuàng)建),Update(更新),Retrieve(讀取),Delete(刪除),這篇文章主要介紹了MySQL表的基本查詢操作,感興趣的朋友一起看看吧
    2024-02-02
  • Centos?7.9安裝MySQL8.0.32的詳細(xì)教程

    Centos?7.9安裝MySQL8.0.32的詳細(xì)教程

    這篇文章主要介紹了Centos7.9安裝MySQL8.0.32的詳細(xì)教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • mysql 提示INNODB錯(cuò)誤的解決方法

    mysql 提示INNODB錯(cuò)誤的解決方法

    解決The‘InnoDB’feature is disabled; you need MySQL built with ‘InnoDB’ to have it
    2011-09-09
  • 快速解決mysql導(dǎo)出scv文件亂碼、躥行的問(wèn)題

    快速解決mysql導(dǎo)出scv文件亂碼、躥行的問(wèn)題

    這篇文章主要介紹了快速解決mysql導(dǎo)出scv文件亂碼、躥行的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • 一次現(xiàn)場(chǎng)mysql重復(fù)記錄數(shù)據(jù)的排查處理實(shí)戰(zhàn)記錄

    一次現(xiàn)場(chǎng)mysql重復(fù)記錄數(shù)據(jù)的排查處理實(shí)戰(zhàn)記錄

    這篇文章主要給大家介紹了一次現(xiàn)場(chǎng)mysql重復(fù)記錄數(shù)據(jù)的排查處理記錄,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-10-10
  • MYSQL explain 執(zhí)行計(jì)劃

    MYSQL explain 執(zhí)行計(jì)劃

    explain顯示了mysql如何使用索引來(lái)處理select語(yǔ)句以及連接表??梢詭椭x擇更好的索引和寫出更優(yōu)化的查詢語(yǔ)句。
    2009-08-08
  • MySQL批量導(dǎo)入Excel數(shù)據(jù)(超詳細(xì))

    MySQL批量導(dǎo)入Excel數(shù)據(jù)(超詳細(xì))

    這篇文章主要介紹了MySQL批量導(dǎo)入Excel數(shù)據(jù)(超詳細(xì)),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助
    2022-08-08
  • MySQL教程DML數(shù)據(jù)操縱語(yǔ)言示例詳解

    MySQL教程DML數(shù)據(jù)操縱語(yǔ)言示例詳解

    這篇文章主要為大家介紹了MySQL教程中DML數(shù)據(jù)操縱語(yǔ)言的示例詳解,要想學(xué)好MySQL最重要的是要先學(xué)好數(shù)據(jù)操縱語(yǔ)言DML,本文對(duì)其進(jìn)行了全面的講解
    2021-10-10
  • MySQL索引下推的實(shí)現(xiàn)示例

    MySQL索引下推的實(shí)現(xiàn)示例

    索引下推是MySQL 5.6引入的優(yōu)化技術(shù),旨在減少查詢過(guò)程中的不必要行訪問(wèn)和回表操作,從而提升查詢性能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-10-10

最新評(píng)論