您现在的位置是:亿华云 > IT科技类资讯
MySQL 查询重复数据,删除重复数据保留id最小的一条作为唯一数据
亿华云2025-10-04 03:55:08【IT科技类资讯】0人已围观
简介开发背景:最近在做一个批量数据导入到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 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 去删除其他重复多余的查除重数据。
结果如下图:
总结:
很多东西都是询重需要自己一步一步的去探究的,当然网上的复数复数建议也是非常宝贵的借鉴和资源,无论做什么开发我们都需要理解它的工作原理才能够更好的掌握它。
网站模板很赞哦!(63993)
热门文章
站长推荐
a、变更前的公司证件扫描件(代码证或者营业执照)及联系人身份证复印件、变更后的公司证件扫描件(代码证或者营业执照)及新的联系人身份证复印件;身份证复印件需本人签名,公司证件复印件需加盖公章。
如何保证IT与OT的安全融合
超实用的Tomcat启动脚本实现
Esp8266入门之一串口输出 Helloword 程序
4、企业无形资产:通用网站已成为企业网络知识产权的重要组成部分,属于企业的无形资产,也有助于提升企业的品牌形象和技术领先形象。它是企业品牌资产不可或缺的一部分。
深入理解JVM,7种垃圾收集器,看完我跪了
手把手教你在 CentOS7 上搭建 Nginx
自己动手用C语言写一个服务器和客户端(TCP)