最近在做一个批量数据导入到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)
#查询显示重复的数据都是显示最前面的几条,因此不需要查询是询重否最小值
更加简单快捷的方式:
这是老飞飞的前辈给了一个更加方便,简洁的复数复数写法(非常感谢大佬的方法):
DELETE FROM brand WHERE Id NOT IN (SELECT Id FROM (SELECT MIN(Id) AS Id FROM brand GROUP BY brandName) t)
这句的意思其实就是,通过分组统计出数据库中不重复的最小数据id编号,让后通过 not in 去删除其他重复多余的数据。
结果如下图:
很多东西都是需要自己一步一步的去探究的,当然网上的建议也是非常宝贵的借鉴和资源,无论做什么开发我们都需要理解它的工作原理才能够更好的掌握它。
责任编辑:武晓燕 来源: 追逐时光者 MySQL查询重复(责任编辑:时尚)
赛生药业(06600.HK)年度实现纯利7.5亿元 每股基本盈利约为人民币1.38元
天津证监局召开2022年辖区期货监管工作会议 结合实际提出监管要求
首发RTX 40+13代i9旗舰电竞本 ROG枪神7Plus超竞版到手价仅19999元
双模屏显超跑 雷柏VT950S双模无线游戏鼠标到手仅249元