MySQL删除表中大批量的数据

红薯 发布于 2009/01/06 11:30
阅读 2K+
收藏 4

假设有一个表(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万条记录成功删除。

加载中
0
呼噜呼噜睡翻天
呼噜呼噜睡翻天
我的mysql版本是5.5.44,执行这个删除语句删不掉数据,不知道大神遇到这种情况没有
红薯
红薯
不能够吧?
返回顶部
顶部