当前位置:首页 > MySQL教程 > 正文内容

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

搜教程4年前 (2019-12-01)MySQL教程176
本篇文章给人人带来的内容是关于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网别的相干文章!

扫描二维码推送至手机访问。

版权声明:本文由搜教程网发布,如需转载请注明出处。

本文链接:https://www.sojiaocheng.cn/15564.html

标签: distinctmysql
分享给朋友:

“SQL中关于distinct关键字的四种用法【MySQL教程】,distinct,mysql” 的相关文章

mysql群集索引的有哪些瑕玷【MySQL教程】,mysql,缺点,哪些

 聚簇索引并非一种零丁的索引范例,而是一种数据存储体式格局(不是数据构造,而是存储构造),细致细节依赖于其完成体式格局,但innodb的聚簇索引实际上是在同一个构造中保留了btree索引和数据行。   当表有索引时,它的数据行实际上存放在索引的叶子页中,属于聚簇示意数据行和相邻的键值紧凑地存储在一...

GreenPlum中一样平常SQL剧本【MySQL教程】,GreenPlum,脚本,日常

--1.指定月份统共若干天 SELECT EXTRACT(DAY FROM CAST('2017-08-01' AS DATE) + INTERVAL '1 month' - INTERVAL '1 day') SELECT EXTRACT(DAY FROM CAST(TO_CHAR(N...

cookie属性和要领剖析【MySQL教程】,cookie,ie,解析

cookie属性和要领剖析【MySQL教程】,cookie,ie,解析

cookie属性详解 在chrome掌握台中的resources选项卡中能够看到cookie的信息。 一个域名下面能够存在着很多个cookie对象。 name字段为一个cookie的称号。 value字段为一个cookie的值。 domain字段为能够接见此cookie的域名。...

MySQL慢查询日记的设置以及运用教程详解【MySQL教程】,MySQL,以及,配置

MySQL慢查询日记的设置以及运用教程详解【MySQL教程】,MySQL,以及,配置

慢查询日记用于纪录一些过慢的查询语句,能够协助管理员剖析问题所在,下面这篇文章重要给人人引见了关于MySQL慢查询日记的设置与运用教程,文中经由过程示例代码引见的异常细致,须要的朋侪能够参考下。 媒介 MySQL慢查询日记是我们在一样平常事情中经常会碰到的一个功用,MySQL慢查询日记供应了...

mysql数据库在Centos7下没法长途衔接的缘由以及处理详解【MySQL教程】,Centos7,mysql,数据库

MySQL是由Oracle公司开辟的开源SQL数据库治理体系,下面这篇文章重要给人人引见了关于在Centos7下没法长途衔接mysql数据库的缘由与处理要领,文中经由过程示例代码引见的异常细致,须要的朋侪能够参考自创,下面来一同看看吧。 媒介 近来在工作中遇到一个题目,发如今Centos7体...

mysql 设置参数详解【MySQL教程】,mysql,详解,配置

[client] port = 3306 socket = /var/lib/mysql/mysql.sock [mysql]#这个设置段设置启动MySQL效劳的前提;在这类状况下,no-auto-rehash确保这个效劳启动得比较快。 no-auto-rehash [mysq...