mysql一次性删除千万调记录的方案

临时需求,因为数据库一张表的数据量已经在4000万条,现在需要删除无用数据,大约3000万条,执行一晚上后早上一看,mysql报错提示磁盘空间不足,怀疑是日志引起,于是百度....

可行方案:

先建立一个旧表和新表结构一样

CREATE TABLE 新表 SELECT * FROM 旧表 WHERE 1=2;//筛选条件是选不出数据的

然后导入自己不需要删除的数据

INSERT INTO 新表 SELECT * FROM 旧表 WHERE 查询条件

然后就可以干掉旧表或者把新表数据倒回去了

再附加一个性能指标:这么导入一个1.5G大小7百多万行记录的表,只需要4分钟多点。

转自:https://blog.csdn.net/wsfzj123/article/details/97236051?utm_medium=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.edu_weight&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.edu_weight