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)
    自有风云来时雨, 似有风霜沾蓑衣
  • 相关阅读:
    CSS3动画基本的转换和过渡
    学习进度(2016.4.3)
    敏捷开发方法综述
    学习进度(2016.3.27)
    数组问题(二)求环形数组子数组和的最大值
    数组问题(一)求子数组和的最大值
    学习进度(2016.3.20)
    程序设计之四则运算三
    学习进度(2016.3.13)
    Right-BICEP 测试四则运算二程序
  • 原文地址:https://www.cnblogs.com/meipu/p/13365743.html
Copyright © 2011-2022 走看看