mysql去重distinct
如果只查一个表中的一个字段时,可以达到根据该字段去重的效果
如果查询一个表中的多个字段时,此时就是去掉该记录中的字段数据,所有都重复的记录,一般用于不重复记录的条数
例如:
用distinct来返回不重复的用户名:select distinct name from user;,结果为:
这样只把不重复的用户名查询出来了,但是用户的id,并没有被查询出来:select distinct name,id from user;,这样的结果为:
distinct name,id 这样的mysql 会认为要过滤掉name和id两个字段都重复的记录,如果sql这样写:select id,distinct name from user,这样mysql会报错,因为distinct必须放在要查询字段的开头。
所以一般distinct用来查询不重复记录的条数。
如果要查询不重复的记录,有时候可以用group by :
select id,name from user group by name;