数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

用Distinct在MySQL中查询多条不重复记录值[1]


发布日期:2020年04月14日
 
用Distinct在MySQL中查询多条不重复记录值[1]

在使用 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

[] [] []

               

上一篇:数据库应用经验:如何简单安装MySQL数据库

下一篇:用Distinct在MySQL中查询多条不重复记录值[3]