如何在不停機的情況下刪除數百萬條MySQL 行
面對導致數百萬重複行的bug,找到刪除最大限度地減少停機時間的策略至關重要。
一種選擇是在循環中執行大量較小的刪除查詢。但是,這種方法可能會給資料庫帶來壓力並延長刪除過程。
另一個選項是重新命名現有表,建立一個新的空表,對重命名的表執行清理,然後將資料合併回原始表。雖然這種方法提供了最小的中斷,但它帶來了邏輯挑戰,包括潛在的資料遺失和需要細緻的資料合併。
更有效的解決方案是循環執行以下查詢,並具有較短的睡眠時間迭代之間:
DELETE FROM `table` WHERE (whatever criteria) ORDER BY `id` LIMIT 1000
透過將一次刪除限制為1000 行並添加較短的睡眠間隔,此技術允許其他查詢交錯並防止表鎖定。隨著迭代的繼續,受影響的行數將逐漸減少,直到為零。
這種方法將效率與最少的停機時間結合起來,使其成為刪除大量行而不破壞網站功能或使用者體驗的合適選擇。
以上是如何在不停機的情況下刪除數百萬條 MySQL 行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!