zoukankan      html  css  js  c++  java
  • Mysql查重去重操作

    有这么一张表:

     里面的技术重复了2次,采购重复了一次。

    使用如下语句:

    select * from test GROUP BY name HAVING COUNT(*) >1

    效果如下:

     可以看到返回的值与重复的次数不一样。

    select * from test where name in(select name from test GROUP BY name HAVING COUNT(name) >1);

    使用这个语句,可以把所有name一样的都返回。

    效果如下:

    select distinct name,code from test where name=0

    使用上面的代码,可以将name,code字段中重复的数据去除以后再返回,

    效果如下:

    select name,code from test where name=0 group by name

    这个语句也是一样的效果

    SELECT * FROM test WHERE name IN (SELECT `name` from test GROUP BY `name` HAVING COUNT(1)>1) AND id NOT in (SELECT min(id) from test GROUP BY `name` HAVING count(1)>1)
    SELECT * from test where id not in (SELECT dt.minno from (SELECT MIN(id) as minno from test GROUP BY name)dt)

    删除多余数据且只保留1条

    delete from test where name in (SELECT t.name from (SELECT name from test GROUP BY name HAVING COUNT(1)>1)t) and id not in (SELECT dt.minno from (SELECT min(id) as minno from test GROUP BY name HAVING count(1)>1)dt)
    DELETE FROM `test` WHERE id NOT IN(SELECT * FROM(SELECT id FROM `test` GROUP BY name)AS A)
    自有风云来时雨, 似有风霜沾蓑衣
  • 相关阅读:
    objectMediator
    vi
    string regex
    ar
    widget class in class
    Makefile 语法分析 第三部分
    在Makefile中的 ".PHONY "是做什么的?
    】openssl移植Android使用及其相关经验分享
    精品Android源码推荐,看了绝不后悔
    Makefile 语法分析 第三部分
  • 原文地址:https://www.cnblogs.com/meipu/p/13365743.html
Copyright © 2011-2022 走看看