使用一个字段很容易找到重复项:

SELECT name, COUNT(email)
FROM users
GROUP BY email
HAVING COUNT(email) > 1
所以如果我们有一张 table
ID   NAME   EMAIL
1    John   asd@asd.com
2    Sam    asd@asd.com
3    Tom    asd@asd.com
4    Bob    bob@asd.com
5    Tom    asd@asd.com
这个查询会给我们 John, Sam, Tom, Tom 因为他们都有相同的 email
但是,我想要的是获得具有相同 email name 的重复项。
也就是说,我想得到“汤姆”,“汤姆”。
我需要这个的原因:我犯了一个错误,并允许插入重复的 nameemail 值。现在我需要删除/更改重复项,所以我需要先找到它们。

最佳答案

SELECT
    name, email, COUNT(*)
FROM
    users
GROUP BY
    name, email
HAVING
    COUNT(*) > 1

只需对两列进行分组。

注意:旧的 ANSI 标准是在 GROUP BY 中包含所有非聚合列,但这已经随着 "functional dependency" 的想法而改变:



支持不一致:
  • 最近的 PostgreSQL supports it
  • SQL Server(与 SQL Server 2017 相同)仍然需要 GROUP BY 中的所有非聚合列。
  • MySQL 是不可预测的,你需要 sql_mode=only_full_group_by :
  • GROUP BY lname ORDER BY showing wrong results ;
  • Which is the least expensive aggregate function in the absence of ANY()(见已接受答案中的评论)。
  • Oracle 不够主流(警告:幽默,我不了解 Oracle)。
  • 关于sql - 在 SQL 表中查找重复值,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/2594829/

    10-13 06:45
    查看更多