您现在的位置是:网站首页> 编程资料编程资料
MySQL查询重复数据(删除重复数据保留id最小的一条为唯一数据)_Mysql_
2023-05-27
415人已围观
简介 MySQL查询重复数据(删除重复数据保留id最小的一条为唯一数据)_Mysql_
开发背景:
最近在做一个批量数据导入到MySQL数据库的功能,从批量导入就可以知道,这样的数据在插入数据库之前是不会进行重复判断的,因此只有在全部数据导入进去以后在执行一条语句进行删除,保证数据唯一性。
下面话不多说了,来一起看看详细的介绍吧
实战:
表结构如下图所示:
表明:brand
操作:
使用SQL语句查询重复的数据有哪些:
SELECT * from brand WHERE brandName IN( select brandName from brand GROUP BY brandName HAVING COUNT(brandName)>1 #条件是数量大于1的重复数据 )
使用SQL删除多余的重复数据,并保留Id最小的一条唯一数据:
注意点:
错误SQL:DELETE FROM brand WHERE brandName IN (select brandName from brand GROUP BY brandName HAVING COUNT(brandName)>1)
AND Id NOT IN (select MIN(Id) from brand GROUP BY brandName HAVING COUNT(brandName)>1)
提示: You can't specify target table 'brand' for update in FROM clause 不能为FROM子句中的更新指定目标表“brand”
原因是:不能将直接查处来的数据当做删除数据的条件,我们应该先把查出来的数据新建一个临时表,然后再把临时表作为条件进行删除功能
正确SQL写法: DELETE FROM brand WHERE brandName IN (SELECT brandName FROM (SELECT brandName FROM brand GROUP BY brandName HAVING COUNT(brandName)>1) e) AND Id NOT IN (SELECT Id FROM (SELECT MIN(Id) AS Id FROM brand GROUP BY brandName HAVING COUNT(brandName)>1) t) #查询显示重复的数据都是显示最前面的几条,因此不需要查询是否最小值
结果如下图:

总结:
很多东西都是需要自己一步一步的去探究的,当然网上的建议也是非常宝贵的借鉴和资源,无论做什么开发我们都需要理解它的工作原理才能够更好的掌握它。
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
相关内容
- CMD命令操作MySql数据库的方法详解_Mysql_
- Mysql5.6修改root密码教程_Mysql_
- MySql闪退和服务无法启动的解决方法_Mysql_
- Mysql5.7修改root密码教程_Mysql_
- mysql的集群模式 galera-cluster部署详解_Mysql_
- getdata table表格数据join mysql方法_Mysql_
- MySQL开启Slow慢查询的方法示例_Mysql_
- 使用SQL语句统计数据时sum和count函数中使用if判断条件的讲解_Mysql_
- Mysql Update批量更新的几种方式_Mysql_
- 抽取oracle数据到mysql数据库的实现过程_Mysql_
