过期罐头电脑论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 5656|回复: 0
收起左侧

mysql查询某个字段不重复值的方法

[复制链接]
稀瞳幽 2013-6-14 07:53:21 | 显示全部楼层
在使用mysql时,有时需要.查询出某个字段不重复的记录,虽然mysql提供有distinct这个关键字来过滤掉多余的重复记录只保留一条,但常常只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是distinct只能返回它的目的字段,而无法返回其它字段。那么该如何解决这个问题呢?下面是具体的解决方法,供大家参考:
下面先来看看例子:
表的构造 `member`
20131118181734292380.jpg
转存表中的数据 `member`
20131118181734292380.jpg
库构造大约这样,这只是一个简单的例子,实际状况会复杂得多。
比方我想用一条语句查询得到name不重复的所有数据,那就必须使用distinct去掉多余的重复记录
20131118181734292380.jpg
telephone的结果是:
20131118181734292380.jpg
仿佛到达效果了,可是,我想要得到的是id值呢?改一下查询语句吧: :
20131118181734292380.jpg
结果会是:
20131118181734292380.jpg
distinct怎么没起作用?作用是起了的,不过他同时作用了两个字段,也就是必须得id与name都相同的才会被排除。我们再改改查询语句: :
20131118181734292380.jpg
很遗憾,除了错误信息你什么也得不到,distinct必须放在开头。难到不能把distinct放到where条件里?能,照样报错。
该怎样处理呢?我们用函数统计需要.不重复的字段。竟然成功了。
现在将完整语句放出:
20131118181734292380.jpg
结果:

目的到达。可以解决问题就可以了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

一键重装系统|雨人系统下载|联系我们|网站地图|过期罐头电脑论坛

GMT+8, 2024-12-23 08:40 , Processed in 0.040259 second(s), 28 queries .

官方免责声明:本站内容来自网友和互联网.若侵犯到您的版权.请致信联系,我们将第一时间删除相关内容!

Powered by Discuz!

专注于win7_win10_win11系统下载装机

© 2010-2023 GQGTPC.Com

快速回复 返回顶部 返回列表