【问题标题】:Select all but ignore duplicates [duplicate]选择所有但忽略重复项[重复]
【发布时间】:2014-04-25 22:38:20
【问题描述】:

我有一个 mysql 表,其中一个字段将包含重复项。我正在尝试选择所有但忽略此字段中存在重复的所有行。

因此,例如,如果我总共有 10 行,其中 3 行有重复,我想返回 8 行。 7 个是唯一的和 3 个重复项中的 1 个。

我尝试过 distinct 和 group by 都没有成功。他们忽略所有 3 个重复项。

这是我尝试过的:

SELECT *
FROM directory_listings
GROUP BY url
WHERE status = 'approved'
ORDER BY site_name ASC
LIMIT $start, $per_page

SELECT * DISTINCT url
FROM directory_listings
WHERE status = 'approved'
ORDER BY site_name ASC
LIMIT $start, $per_page

【问题讨论】:

  • 为什么要返回 1 个重复项?
  • 为了完整起见,我需要返回其中一个副本。如果我有记录 a、b、b、c、d,那么我想返回 a、b、c、d
  • @Ruf1 所有列的重复值是否相同,还是只是某个列中的重复?
  • @AlexW - 它只是“url”列,可能有重复

标签: mysql sql group-by distinct


【解决方案1】:

@AlexW - 这只是 'url' 列可能有重复 - Ruf1 9 分钟前

如果您更正语法,那么您的第一个查询将起作用 - GROUP BY 必须遵循 WHERE(根据 the docs):

SELECT *
FROM directory_listings
WHERE status = 'approved'
GROUP BY url
ORDER BY site_name ASC

Here's an example of a working query in SQL Fiddle.

【讨论】:

  • 完美运行,非常感谢。
  • 我还需要一个类似的查询来确定唯一行的数量。这是正确的还是我使用组:“SELECT COUNT(DISTINCT url) FROM directory_listings WHERE status = 'approved'”
  • 应该可以正常工作;另见stackoverflow.com/q/4131937/2359271。如果您使用GROUP BY,您将获得每个组的单独计数(这对于查找重复项很有用,如this example!)
【解决方案2】:

SELECT DISTINCT 的语法错误:

http://dev.mysql.com/doc/refman/5.6/en/select.html

另外,GROUP BY 不能消除重复的唯一原因是WHERE 子句取消了某些行的资格(即它们在statusurl 方面都不是重复的)。

【讨论】:

  • +1 表示关于 WHERE 子句的好点。通过明确给出正确的语法而不是仅链接文档,IMO 这个答案将得到很大改善。我知道当我开始使用 SQL 时,我发现文档中的语法描述非常混乱;并且外部链接可能不稳定。
猜你喜欢
  • 2020-05-31
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2022-11-10
  • 1970-01-01
  • 2012-09-01
  • 1970-01-01
  • 2023-01-10
相关资源
最近更新 更多