SQL删除重复数据的实例教程

目录
  • 1 SQL去重
  • 2 distinct
  • 3 group by
    • 1. 查询根据名字去重后数据(名字相同取id值大的)
    • 2. 删除名字相同数据(名字相同保留id值大的)
  • 4 总结

    1 SQL去重

    SQL中去除完全相同数据可以用distinct关键字,任意字段去重可以用group by,以下面的数据表为例。

    2 distinct

    存在两条完全相同的纪录,用关键字distinct就可以去掉

    根据单个字段去重,能精确去重;

    作用在多个字段时,只有当这几个字段的完全相同时,才能去重;

    关键字distinct只能放在SQL语句中的第一个,才会起作用

    SQL删除重复数据的实例教程

    SQL删除重复数据的实例教程

    SQL删除重复数据的实例教程

    一般用来返回不重复的记录条数,返回不重复的条数(去掉test重复的,就剩下6条)

    SQL删除重复数据的实例教程

    3 group by

    1. 查询根据名字去重后数据(名字相同取id值大的)

    SELECT * FROM stu WHERE id IN (SELECT MAX(id) FROM stu GROUP BY `name`)
    

    SQL删除重复数据的实例教程

    2. 删除名字相同数据(名字相同保留id值大的)

    group by + count + max去掉重复数据

    1)SELECT * FROM stu

    SQL删除重复数据的实例教程

    2)加上group by 后,会将重复的数据去掉了

    SQL删除重复数据的实例教程

    3) 条件(名字)是数量大于1的重复数据

    SELECT `name` FROM stu GROUP BY `name` HAVING COUNT(`name`) qTYIMBZp> 1
    
    #条件是数量大于1的重复数据
    SELECT * FROM stu WHERE `name` IN(
    SELECT `name` FROM stu GROUP BY `name` HAVING COUNT(`name`)>1 
    )
    

    SQL删除重复数据的实例教程

    4)查看某字段重复数据的id

    SELECT id, COUNT(*) FROM stu 
    GROUP BY NAME DESC HAVING(COUNT(*) > 0)
    

    SQL删除重复数据的实例教程

    5)查询所有重复数据

    SELECT * FROM stu WHERE NAME IN (SELECT `name` FROM stu GROUP BY `name` HAVING COUNT(`name`) > 1)
    

    SQL删除重复数据的实例教程

    5) 去重

    可以使用distinct去重(返回不重复的用户名)

    删除多余的重复记录(name),只保留id最大的记录。

    DELETE FROM stu 
    WHERE id NOT IN ( SELECT a.id FROM ( SELECT MAX( id ) AS id FROM stu GROUP BY `name` )a )
    

    或者

     DELETE FROM stu WHERE `name` IN (SELECT `name` FROM (SELECT `name` FROM stu GROUP BY `name` HAVING COUNT(`name`)>1) e)
     AND id NOT IN (SELECT id FROM (SELECT MAX(id编程客栈) AS id FROM stu GROUP BY `name` HAVING COUNT(`name`)>1) t)
     #查询显示重复的数据都是显示最前面的几条,因此不需要查询是否最小值
    

    错误删除

    DELETE FROM stu WHERE name IN (SELECT name FROM stu GROUP BY name HAVING COUNT(name)>1)
    AND id NOT IN (SELECT MAX(id) FROM stu GROUP BY stu HAVING COUNT(name)>1)

    原因是:不能将直接查处来的数据当做删除数据的条件,我们应该先把查出来的数据新建一个临时表,然后再把临时表作为条件进行删除功能

    SQL删除重复数据的实例教程

    扫一扫手机访问