假设有一个表(osc_logs)有2000万条记录,我们要在业务不停止的情况下删除其中status=1的所有记录,差不多有1800万条,直接执行 DELETE FROM osc_logs WHERE status=1 会发现删除失败,因为lock wait timeout exceed的错误。因为这条语句所涉及的记录数太多了,因此我们可以分批来删除,比如每10000条进行删除,那么我们可以利用MySQL这样的语句来完成
DELETE FROM osc_logs WHERE status=1 ORDER BY log_id LIMIT 10000;
然后分多次执行就可以把这1800万条记录成功删除。
本文介绍了一种在不中断业务的情况下,如何有效地批量删除MySQL数据库中大量记录的方法。通过使用LIMIT关键字分批删除,避免了因锁等待超时而导致的操作失败。
1099

被折叠的 条评论
为什么被折叠?



