首頁  >  文章  >  資料庫  >  如何在不停機的情況下刪除數百萬條 MySQL 行?

如何在不停機的情況下刪除數百萬條 MySQL 行?

Linda Hamilton
Linda Hamilton原創
2024-11-07 11:11:02303瀏覽

How to Delete Millions of MySQL Rows Without Downtime?

如何在不停機的情況下刪除數百萬條MySQL 行

面對導致數百萬重複行的bug,找到刪除最大限度地減少停機時間的策略至關重要。

一種選擇是在循環中執行大量較小的刪除查詢。但是,這種方法可能會給資料庫帶來壓力並延長刪除過程。

另一個選項是重新命名現有表,建立一個新的空表,對重命名的表執行清理,然後將資料合併回原始表。雖然這種方法提供了最小的中斷,但它帶來了邏輯挑戰,包括潛在的資料遺失和需要細緻的資料合併。

更有效的解決方案是循環執行以下查詢,並具有較短的睡眠時間迭代之間:

DELETE FROM `table`
WHERE (whatever criteria)
ORDER BY `id`
LIMIT 1000

透過將一次刪除限制為1000 行並添加較短的睡眠間隔,此技術允許其他查詢交錯並防止表鎖定。隨著迭代的繼續,受影響的行數將逐漸減少,直到為零。

這種方法將效率與最少的停機時間結合起來,使其成為刪除大量行而不破壞網站功能或使用者體驗的合適選擇。

以上是如何在不停機的情況下刪除數百萬條 MySQL 行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn