《Mysql必讀Mysql單文件存儲刪除數(shù)據(jù)文件容量不會減少的bug與解決方法》要點:
本文介紹了Mysql必讀Mysql單文件存儲刪除數(shù)據(jù)文件容量不會減少的bug與解決方法,希望對您有用。如果有疑問,可以聯(lián)系我們。
MySQL的Bug之一:InnoDB ibdata1 never shrinks after data is removed
MYSQL入門
問題描述
MYSQL入門
當(dāng)innodb引擎使用單個文件進行存儲的時候,當(dāng)對數(shù)據(jù)庫中數(shù)據(jù)進行刪除的時候,文件的大小并不會發(fā)生變化,意味著文件將會越來越大并且即使刪除也沒辦法 讓其釋放磁盤的空間.MYSQL入門
驗證過程
MYSQL入門
創(chuàng)建一個測試使用的表,如下創(chuàng)建好t這樣的一個表.MYSQL入門
MYSQL入門
創(chuàng)建簡單的存儲過程來批量的插入數(shù)據(jù).MYSQL入門
MYSQL入門
查看開始前的文件的大小MYSQL入門
MYSQL入門
當(dāng)批量插入接近十萬的數(shù)據(jù)后MYSQL入門
MYSQL入門
然后進行刪除操作MYSQL入門
MYSQL入門
占用磁盤空間并未減少MYSQL入門
解決方案MYSQL入門
兩種方式:
MYSQL入門
1. 先備份后刪除然后進行導(dǎo)入MYSQL入門
mysqldump -uxxx -pxxx --all-databases > db.sql service mysql stop rm ibdata rm ×log文件 service mysql start mysql -uxxx -pxxx < db.sql
2. 把表設(shè)置為單表存儲的形式,這樣每個表中的數(shù)據(jù)單獨存儲,在刪除數(shù)據(jù)的時候,會隨著數(shù)據(jù)的刪除而釋放存儲空間.MYSQL入門
set global innodb_file_per_table = on
總結(jié)MYSQL入門
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流.MYSQL入門
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/3321.html