黑马程序员技术交流社区

标题: 【太原校区】mysql中去重 distinct 用法 [打印本页]

作者: 郝永亮    时间: 2019-5-9 10:06
标题: 【太原校区】mysql中去重 distinct 用法
[size=1.125]mysql中去重 distinct 用法
[size=0.875]在使用MySQL时,有时需要查询出某个字段不重复的记录,这时可以使用mysql提供的distinct这个关键字来过滤重复的记录,但是实际中我们往往用distinct来返回不重复字段的条数(count(distinct id)),其原因是distinct只能返回他的目标字段,而无法返回其他字段,例如有如下表user:

[size=0.875]用distinct来返回不重复的用户名:select distinct name from user;,结果为:

[size=0.875]这样只把不重复的用户名查询出来了,但是用户的id,并没有被查询出来:select distinct name,id from user;,这样的结果为:

[size=0.875]distinct name,id 这样的mysql 会认为要过滤掉name和id两个字段都重复的记录,如果sql这样写:select id,distinct name from user,这样mysql会报错,因为distinct必须放在要查询字段的开头。
[size=0.875]所以一般distinct用来查询不重复记录的条数。
[size=0.875]如果要查询不重复的记录,有时候可以用group by :
[size=0.875]select id,name from user group by name;


作者: 张志辉    时间: 2019-5-9 10:07

作者: miaoxiong    时间: 2019-5-9 10:18

作者: liudongjie    时间: 2019-5-10 17:07

作者: 郝永亮    时间: 2019-6-4 16:50
学习了




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2