SQL中关于distinct关键字的四种用法【MySQL教程】,distinct,mysql
在运用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
以上就是SQL中关于distinct关键字的四种用法的细致内容,更多请关注ki4网别的相干文章!