MySQL InnoDB 資料刪除後磁碟空間釋放不足
眾所周知,MySQL 的InnoDB 儲存引擎在資料行刪除時不會自動釋放分配的磁碟空間從表中刪除。此行為是由於 InnoDB 基於行的儲存模型的性質造成的。當刪除一行時,它所佔用的空間不會立即釋放,而是標記為可供將來插入或表格擴充重複使用。
因此,即使在刪除資料行並執行 OPTIMIZE TABLE 等最佳化命令之後,大小InnoDB 的共用表空間檔案(通常名稱為 ibdata1)可能保持不變。這可能會導致磁碟空間不足的問題,尤其是在有大量表格和頻繁資料刪除操作的環境中。
要解決此問題,使用者有兩個主要選擇:
innodb_data_file_path = ibdata1:10M # shrink to 10 MB
此過程將建立一個具有指定減小大小的新 ibdata1 文件,同時保留原始資料庫中的資料。請記住,此方法在復原過程中可能需要額外的磁碟空間。
以上是MySQL InnoDB刪除資料後為何不釋放磁碟空間,該如何回收?的詳細內容。更多資訊請關注PHP中文網其他相關文章!