临时需求,因为数据库一张表的数据量已经在4000万条,现在需要删除无用数据,大约3000万条,执行一晚上后早上一看,mysql报错提示磁盘空间不足,怀疑是日志引起,于是百度....
可行方案:
先建立一个旧表和新表结构一样
CREATE TABLE 新表 SELECT * FROM 旧表 WHERE 1=2;//筛选条件是选不出数据的
然后导入自己不需要删除的数据
INSERT INTO 新表 SELECT * FROM 旧表 WHERE 查询条件
然后就可以干掉旧表或者把新表数据倒回去了
再附加一个性能指标:这么导入一个1.5G大小7百多万行记录的表,只需要4分钟多点。