会员登录 - 用户注册 - 设为首页 - 加入收藏 - 网站地图 MySQL 查询重复数据,删除重复数据保留id最小的一条作为唯一数据!

MySQL 查询重复数据,删除重复数据保留id最小的一条作为唯一数据

时间:2025-11-05 04:15:14 来源:益强数据堂 作者:数据库 阅读:747次

开发背景:

最近在做一个批量数据导入到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 cant 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)

#查询显示重复的复数复数数据都是显示最前面的几条,因此不需要查询是据删据保否最小值

更加简单快捷的方式:

这是老飞飞的前辈给了一个更加方便,简洁的条作写法(非常感谢大佬的方法):

DELETE FROM brand WHERE Id NOT IN (SELECT Id FROM (SELECT MIN(Id) AS Id FROM brand GROUP BY brandName) t)

这句的意思其实就是高防服务器,通过分组统计出数据库中不重复的数据最小数据id编号,让后通过 not in 去删除其他重复多余的查除重数据。

结果如下图:

总结:

很多东西都是询重需要自己一步一步的去探究的,当然网上的复数复数建议也是非常宝贵的借鉴和资源,无论做什么开发我们都需要理解它的工作原理才能够更好的掌握它。

站群服务器

(责任编辑:人工智能)

推荐内容
  • 探索Toshiba迷你电脑的性能与实用性(一款小巧便携的强力计算机,助您随时随地提升工作效率)
  • Elasticsearch集群多租户解决方案探索
  • 专家视点:传统互联网安全已无法满足物联网需求
  • 物联网安全需要专业技能
  • 毛桃Pe系统教程(打造专属于你的电脑系统,让操作更高效、更顺心)
  • 专访解运洲:物联网技术动态发展,RedCap尚需时间沉淀