过期罐头电脑论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

[网站建设] mysql查询某个字段不重复值的方法

[复制链接]
发表于 2013-6-14 07:53:21 | 显示全部楼层 |阅读模式
发贴请勿包含网站外链(直接下载地址和网盘除外),屡犯者将封禁ID、网址永久屏蔽,www.gqgtpc.com感谢支持!
在使用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
结果:

目的到达。可以解决问题就可以了。

楼主热帖
[系统应用经验技巧] PSP模仿 器在windows操作系统之中运
[Windows10] Win8系统消费者预览版进入安全模式的详细方
[Windows7] Windows7 启动时报错提示:bootMGR is missin
[系统应用经验技巧] 电脑内存大就用64位操作系统
[Windows10] 安装程序过程之中解压文件提示磁盘空间不够
[系统应用经验技巧] 那些Nt内核操作系统之中的里程碑版本
[Windows7] Windows7 64连接WinXP32 上的Epson 1290打印
[Windows7] 怎么提高windows 7 搜索功能的方法
[Windows10] 安装应用程序,会改动 哪些信息?
[Windows7] 怎么 加快Windows 7关机速度

您需要登录后才可以回帖 登录 | 注册

本版积分规则

win7 64位旗舰版下载|win10系统下载|win7旗舰版|联系我们|网站地图|过期罐头电脑论坛

GMT+8, 2017-3-27 06:45 , Processed in 0.263512 second(s), 27 queries .

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

Powered by Discuz!

过期罐头电脑论坛

win7旗舰版_windows10

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