旗下导航:搜·么
当前位置:网站首页 > MySQL教程 > 正文

SQL中关于distinct关键字的四种用法【MySQL教程】,distinct,mysql

作者:搜教程发布时间:2019-12-01分类:MySQL教程浏览:35评论:0


导读:本篇文章给人人带来的内容是关于SQL中关于distinct关键字的四种用法(代码实例),有肯定的参考价值,有须要的朋侪能够参考一下,愿望对你有所协助。在运用mysql时,偶...
本篇文章给人人带来的内容是关于SQL中关于distinct关键字的四种用法(代码实例),有肯定的参考价值,有须要的朋侪能够参考一下,愿望对你有所协助。

在运用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网别的相干文章!

标签:distinctmysql


欢迎 发表评论: