mysql查找删除表中重复数据方法总结

时间:2022-09-22 20:09:56

在数据库表里,我们有时候会保存了很多重复的数据,这些重复的数据浪费资源,我们要将其删除掉,应该怎么处理呢?下面来看一下。

先看下我们的表数据,有一些数据是重复的。

mysql查找删除表中重复数据方法总结

查找重复数据,我们可以使用mysql里的having语句,如图。

mysql查找删除表中重复数据方法总结

执行这个语句后,我们可以看到现在的结果里显示的就是表中重复数据的字段。

mysql查找删除表中重复数据方法总结

要删除这些重复的数据,我们找出这些数据的ID,在select语句里,添加id字段,使用max函数,可以得到重复数据最后面的id。

mysql查找删除表中重复数据方法总结

执行结果如图,得到重复数据的id为8和9。

mysql查找删除表中重复数据方法总结

这样我们就可以使用delete语句来删除这二个id的数据了。

mysql查找删除表中重复数据方法总结

但如果有很多重复的数据,不想一个一个的写这些id怎么办?

添加一个子查询,只把id字段查询出来,如图。

mysql查找删除表中重复数据方法总结

然后在外边添加一个delete语句就行了,详细代码如图。

要注意的是,如果重复数据的行有三行或以上的,我们需要执行这个语句多次才行,因为执行一次只会删除每组重复数据中的一条。

mysql查找删除表中重复数据方法总结