惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

博客园 - 叶小钗
云风的 BLOG
云风的 BLOG
G
Google Developers Blog
S
SegmentFault 最新的问题
罗磊的独立博客
Hugging Face - Blog
Hugging Face - Blog
美团技术团队
爱范儿
爱范儿
博客园 - 三生石上(FineUI控件)
H
Hackread – Cybersecurity News, Data Breaches, AI and More
D
DataBreaches.Net
F
Fortinet All Blogs
TaoSecurity Blog
TaoSecurity Blog
D
Docker
C
Cybersecurity and Infrastructure Security Agency CISA
K
Kaspersky official blog
宝玉的分享
宝玉的分享
腾讯CDC
Google Online Security Blog
Google Online Security Blog
Recorded Future
Recorded Future
T
The Exploit Database - CXSecurity.com
T
The Blog of Author Tim Ferriss
V
V2EX
S
Securelist
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
C
CERT Recently Published Vulnerability Notes
A
Arctic Wolf
Scott Helme
Scott Helme
L
LINUX DO - 热门话题
Y
Y Combinator Blog
P
Proofpoint News Feed
T
Tor Project blog
AWS News Blog
AWS News Blog
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
The Last Watchdog
The Last Watchdog
博客园 - 聂微东
T
Threat Research - Cisco Blogs
B
Blog
Attack and Defense Labs
Attack and Defense Labs
L
Lohrmann on Cybersecurity
C
CXSECURITY Database RSS Feed - CXSecurity.com
阮一峰的网络日志
阮一峰的网络日志
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
IT之家
IT之家
N
News and Events Feed by Topic
博客园 - 司徒正美
H
Help Net Security
C
Cisco Blogs
C
Check Point Blog
S
Secure Thoughts

博客园 - ;姚元培

C#企业级开发案例精解:用经典案例学通 NET技术 NHibernate HibernateTemplate 和Session的区别 HQL中的Like查询需要注意的地方 C# WinForm控件美化扩展系列之TabControl控件(3)-完整版 应用程序权限设计 asp.net MVC 显示数据库中的html 代码 ASP.NET MVC2 使用绑定时 等号和冒号的差别 spring.net asp.net mvc 验证 asp.net防止页面刷新或后退引起重复提交 截获系统注销时候的消息 WeifenLuo.WinFormsUI.DockContent 使用 c# listview 房间列表 百度搜索 asp后台批处理 asp.net数据显示 完善网站程序 脚本攻击防范策略完全篇 asp获取客户端ip http-equiv属性 弹出窗口代码 asp sql语句 javascript with 和 prototype属性 .NET设计模式系列文章 关于rs.bof 和 rs.eof onbeforeunload与onunload事件 HTML特殊字符显示 屏幕捕捉 和批量重名命 html文件 后缀 js dom JavaScrip高级应用:操作模态与非模态对话框 vb常用 如何去除图片连接的边框线 常用CHM帮助文档集锦下载 asp 纪录集 返回首行首列 SQL语句大全 正则表达式30分钟入门教程
使用distinct在mysql中查询多条不重复记录值的解决办法
;姚元培 · 2011-12-16 · via 博客园 - ;姚元培

http://hi.baidu.com/esky9/blog/item/87d08633ffbc4840ad4b5fc0.html

使用distinct在mysql中查询多条不重复记录值的解决办法
2007-11-08 17:50

*    在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供有
distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不
重复记录的条数,而不是用它来返回不重记录的所有值。其原因是distinct只能返
回它的目标字段,而无法返回其它字段,这个问题让我困扰了很久,用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*

*很遗憾,除了错误信息你什么也得不到,distinct必须放在开头。难到不能把
distinct放到where条件里?能,照样报错。。。。。。。*

*很麻烦吧?确实,费尽心思都没能解决这个问题。没办法,继续找人问。*

*拉住公司里一JAVA程序员,他给我演示了oracle里使用distinct之后,也没找到
mysql里的解决方案,最后下班之前他建议我试试group by。*

*试了半天,也不行,最后在mysql手册里找到一个用法,用
group_concat(distinct name)配合group by name实现了我所需要的功能,兴奋,
天佑我也,赶快试试。*

*报错。。。。。。。。。。。。郁闷。。。。。。。连mysql手册也跟我过不去,
先给了我希望,然后又把我推向失望,好狠哪。。。。*

*再仔细一查,group_concat函数是4.1支持,晕,我4.0的。没办法,升级,升完
级一试,成功。。。。。。*

*终于搞定了,不过这样一来,又必须要求客户也升级了。*

*突然灵机一闪,既然可以使用group_concat函数,那其它函数能行吗?*

*赶紧用count函数一试,成功,我。。。。。。。想哭啊,费了这么多工
夫。。。。。。。。原来就这么简单。。。。。。*

*现在将完整语句放出:*

*select *, count(distinct name) from table group by name*

*结果:*

*id name count(distinct name)
1 a 1
2 b 1
3 c 1*

*最后一项是多余的,不用管就行了,目的达到。。。。。*

*唉,原来mysql这么笨,轻轻一下就把他骗过去了,郁闷也就我吧(对了,还有容
容那家伙),现在拿出来希望大家不要被这问题折腾。*

*哦,对,再顺便说一句,group by 必须放在 order by 和 limit之前,不然会报
错,差不多了,发给容容放网站上去,我继续忙碌。。。。。。*

*--------------------------------------------------------------------*


*更郁闷的事情发生了,在准备提交时容容发现,有更简单的解决方法。。。。。。*

*select id, name from table group by name*

*看来对mysql的了解还是太肤浅了,不怕被笑话,发出来让大家别犯同样的错
误。。。。。。*

*文章引用自:
*