本文摘自PHP中文网,作者藏色散人,侵删。
mysql中批量删除数据的方法:首先找出符合条件的最大id;然后在where字段上建立索引;最后通过命令“delete from table_name where id < maxId limit 10000”批量删除数据即可。
推荐:《mysql视频教程》
mysql批量删除大数据
mysql一次性删除大量数据是有可能造成死锁的,而且也会抛异常
1 |
|
这是由于需要删除的数据太大,mysql给的buffer好像只有8MB左右
lock wait timeout exceed 超时
所以需要分批处理,这也是操作大数据时一种常见的思路
网上比较好的一种方法是:
首先找出符合条件的最大id(这里的id是有序的,不需要连续)
1 |
|
在where字段上建立索引可提高效率
千万左右的数据大概需要10多秒
接着按id删除,一次删除10k,循环删除
1 |
|
以上就是mysql中如何批量删除数据的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
mysql和sql是什么?mysql和sql之间的区别有哪些
mysql 客户端不输入用户名和密码直接连接数据库的2个方法
关于mysql函数concat与group_concat使用说明事项
更多相关阅读请进入《mysql》频道 >>

数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。