mysql中distinct和group by过滤删除重复行
发布:smiling 来源: PHP粉丝网 添加日期:2014-10-04 16:59:33 浏览: 评论:0
在mysql中distinct就是可以直接去重的而group by 是分组显示的,但是有朋友在应用中可能会发现distinct并不像官方讲得那有实用了,下面我来介绍一下它们是怎么过滤删除重复行.
下面先来看看例子,代码如下:
- table
- id name
- 1 a
- 2 b
- 3 c
- 4 c
- 5 b
库结构大概这样,这只是一个简单的例子,实际情况会复杂得多,比如我想用一条语句查询得到name不重复的所有数据,那就必须使用distinct去掉多余的重复记录,代码如下:
select distinct name from table
得到的结果是:
- name
- a
- b
- c
好像达到效果了,可是,我想要得到的是id值呢?改一下查询语句吧:
select distinct name, id from table
结果会是:
- id name
- 1 a
- 2 b
- 3 c
- 4 c
- 5 b
distinct怎么没起作用?作用是起了的,不过他同时作用了两个字段,也就是必须得id与name都相同的才会被排除.
我们再改改查询语句:select id, distinct name from table
现在将完整语句放出:
select *, count(distinct name) from table group by name
结果:
- id name count(distinct name)
- 1 a 1
- 2 b 1
- 3 c 1
上面简单但有些地方是不能完成我们的需要的,下面记录了些常用的重复记录操作语句
查询及删除重复记录的方法.
1、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,代码如下:
- select * from people
- where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)
2、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录,代码如下:
- delete from people
- where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)
- and rowid not in (select min(rowid) from people group by peopleId having count(peopleId )>1)
3、查找表中多余的重复记录,多个字段,代码如下:
- select * from vitae a
- where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
4、删除表中多余的重复记录,多个字段,只留有rowid最小的记录,代码如下:
- delete from vitae a
- where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
- and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
5、查找表中多余的重复记录,多个字段,不包含rowid最小的记录,代码如下:
- select * from vitae a
- where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
- and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1) --phpfensi.com
Tags: distinct group by过滤删除重复行
相关文章
- ·mysql中distinct去除重复值方法(2014-10-09)
- ·mysql中过滤重复记录之distinct用法(2014-10-12)
- ·mysql GROUP BY 与 ORDER BY数据排序问题(2014-09-24)
- ·mysql关联查询中GROUP BY的例子(2014-09-24)
- ·mysql中GROUP BY 和ORDER BY 组合使用注意事项(2014-09-24)
- ·MYSQL中group by做分组查询并排序(2014-09-25)
- ·解决MySQL中无GROUP BY直接HAVING的问题(2014-09-27)
- ·mysql数据库分组,GROUP BY,查询实例(2014-09-27)
- ·mysql函数group_concat使用方法(2014-10-01)
- ·mysql中group by用法与having合用注意事项(2014-10-02)
- ·MySql中GROUP_CONCAT()函数使用详解(2014-10-03)
- ·mysql 分组group by排序取每条记录中,时间最大的一条记录(2014-10-03)
- ·mysql获取group by的总记录行数方法(2014-10-03)
- ·mysql group by 排序问题一些自我理解(2014-10-04)
- ·mysql group_concat函数使用方法(2014-10-08)
- ·解决mysql group by不能排序方法(2014-10-08)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)