在使用 mysql时有时需要查询出某个字段不重复的记录虽然mysql提供有distinct这个关键字来过滤掉多余的重复记录只保留一条但往往只用它来返回不重复记录的条数而不是用它来返回不重记录的所有值其原因是distinct只能返回它的目标字段而无法返回其它字段这个问题让我困扰了很久用distinct不能解决的话我只有用二重循环查询来解决而这样对于一个数据量非常大的站来说无疑是会直接影响到效率的所以我花了很多时间来研究这个问题网上也查不到解决方案期间把朋友拉来帮忙结果是我们两人都郁闷了!
下面先来看看例子
table
id name
a
b
c
c
b
库结构大概这样这只是一个简单的例子实际情况会复杂得多
比如我想用一条语句查询得到name不重复的所有数据那就必须使用distinct去掉多余的重复记录
select distinct name from table
得到的结果是:
name
a
b
c
好像达到效果了可是我想要得到的是id值呢?改一下查询语句吧:
select distinct name id from table
[] [] []