当前位置: 移动技术网 > IT编程>数据库>Mysql > MySQL查询重复数据(删除重复数据保留id最小的一条为唯一数据)

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

2019年05月28日  | 移动技术网IT编程  | 我要评论
开发背景: 最近在做一个批量数据导入到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)

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

结果如下图:


总结:

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

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对移动技术网的支持。

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网