使用一个字段很容易找到重复项:
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
的重复项。也就是说,我想得到“汤姆”,“汤姆”。
我需要这个的原因:我犯了一个错误,并允许插入重复的
name
和 email
值。现在我需要删除/更改重复项,所以我需要先找到它们。 最佳答案
SELECT
name, email, COUNT(*)
FROM
users
GROUP BY
name, email
HAVING
COUNT(*) > 1
只需对两列进行分组。
注意:旧的 ANSI 标准是在 GROUP BY 中包含所有非聚合列,但这已经随着 "functional dependency" 的想法而改变:
支持不一致:
sql_mode=only_full_group_by
:关于sql - 在 SQL 表中查找重复值,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/2594829/