mysql 屏蔽 相同 行

来源:百度知道 编辑:UC知道 时间:2024/05/14 05:50:06
如果搜出来的结果有
user times
张三 6:30
张三 7:30
张三 8:40
李四 8:50
王五 9:00

要求就user行屏蔽相同的行
最后我使用group by解决了, DISTINCT不知为何用了跟没用一样

一个表有可能在同一列中有重复的值。例如,数据库pubs的表authors中有两个作者的名字是Ringer。如果你从这个表中取出所有的名字,名字Ringer将会显示两次。
在特定情况下,你可能只有兴趣从一个表中取出互不相同的值。如果一个字段有重复的值,你也许希望每个值只被选取一次,你可以使用关键字DISTINCT来做到这一点:

SELCET DISTINCT au_lname FROM authors WHERE au_lname="Ringer"

当这个SELECT语句执行时,只返回一个记录。通过在SELECT语句中包含关键字DISTINCT,你可以删除所有重复的值。例如,假设有一个关于新闻组信息发布的表,你想取出所有曾在这个新闻组中发布信息的人的名字,那么你可以使用关键字DISTINCT。每个用户的名字只取一次——尽管有的用户发布了不止一篇信息。
同样我们可以使用:DISTINCTROW
将整条记录重复的记录忽略掉,而不是只有针对某一个字段的数据。
SELECT DISTINCTROW 公司名称

FROM 顾客表格 INNER JOIN 订单表格

ON 顾客表格.顾客ID=订单表格.顾客ID

ORDER BY 公司名称;

如果您忽略 DISTINCTROW 则会对每个公司产生一行以下的订单数据。此外,若是DISTINCTROW只有用在一个表格当中,则会被省略掉。
警告:
如同ORDER BY子句一样,强制服务器返回互不相同的值也会增加运行开销。福气不得不花费一些时间来完成这项工作。因此,不是必须的时候不要使用关键字DISTINCT。 select DISTINCT:取出互不相同的记录!

select distinct user, times from (表名)