SQL中关于distinct关键字的四种用法【MySQL教程】,distinct,mysql
作者:搜教程发布时间:2019-12-01分类:MySQL教程浏览:35评论:0
在运用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网别的相干文章!
相关推荐
- 如何修改mysql的默认时区_MySQL教程,mysql,时区
- mysql数据库如何创建数据表_MySQL教程,mysql,数据表
- linux源码安装mysql5.7_MySQL教程,linux,mysql,mysql5.7
- mysql外键约束怎么写_MySQL教程,mysql,外键约束
- mysql如何设置字符集为UTF8_MySQL教程,mysql,UTF8,字符集
- mysql怎么创建数据库_MySQL教程,mysql,数据库
- 如何查看mysql的日志文件_MySQL教程,mysql,日志文件
- mysql如何删除表中一行数据?_MySQL教程,mysql
- access是数据库管理系统吗_MySQL教程,access,mysql
- mysql修改字段类型有哪些?_MySQL教程,mysql,修改字段
你 发表评论:
欢迎- MySQL教程排行
-
- 1必学!MySQL数据库查询之limit的使用方法_MySQL教程,mysql
- 2mysql索引介绍_MySQL教程,mysql,索引,介绍
- 3如何理解mysql锁机制_MySQL教程,理解,mysql,锁,机制
- 4一文详解mysql视图_MySQL教程,mysql,视图
- 5Mysql如何挂盘_MySQL教程,Mysql
- 6mysql实现linux下数据库目录迁移_MySQL教程,mysql,linux,数据库,目录,迁移
- 7mysql中key 、primary key 、unique key 与index区别详解_MySQL教程,mysql
- 8分离数据库和附加数据库的区别_MySQL教程,数据库
- 9开启mysql慢查询日志的方法_MySQL教程,开启,mysql,慢查询,日志,方法
- 最新文章
- 广而告之