编写SQL查询以在名为Person的表中查找所有重复的电子邮件。
+----+---------+
| Id | Email |
+----+---------+
| 1 | a@b.com |
| 2 | c@d.com |
| 3 | a@b.com |
+----+---------+
例如,您的查询应为上表返回以下内容:
+---------+
| Email |
+---------+
| a@b.com |
+---------+
这是解决SQL查询中此问题的三种方法,一种是通过使用group by子句,第二种是使用自联接,然后是第三种是使用带有存在子句的子查询。 虽然我同意可以用其他方法解决此问题,但这也是如何使用
SQL GROUP BY和HAVING子句 。
解决此问题的最简单方法是使用GROUP BY和HAVING子句。 使用GROUP BY将电子邮件上的结果集分组,这会将所有重复的电子邮件归为一组,现在,如果特定电子邮件的计数大于1,则表示它是重复的电子邮件。 这是查找重复电子邮件的SQL查询:
#在下面写你的MySQL查询语句
SELECT Email FROM Person GROUP BY Email HAVING COUNT(Email) > 1
这也是我接受的有关LeetCode的答案。
顺便说一下,有两种其他方法可以解决此问题,一种方法是使用“自我连接”。 如果您还记得,在“自我联接”中,我们联接同一表的两个实例以将一条记录与另一条记录进行比较。 现在,如果表第一个实例中一个记录的电子邮件等于第二个表中另一个记录的电子邮件,则意味着该电子邮件是重复的。 这是使用自连接的SQL查询
#在下面写你的MySQL查询语句
SELECT DISTINCT a.Email FROM Person a JOIN Person b ON a.Email = b. Email WHERE a.Id != b.Id
请记住在此处使用关键字distant,因为它将重复打印电子邮件,使其重复出现在表格中的次数。 这也是Leetcode中公认的解决方案。
您甚至可以使用相关子查询来解决此问题。 在相关子查询中,将对外部查询中的每个记录执行内部查询。 因此,使用相关子查询将一封电子邮件与同一表中的其余电子邮件进行比较。 这是解决方案查询:
SELECT DISTINCT p1.Email FROM Person p1 WHERE EXISTS(
SELECT *
FROM Person p2
WHERE p2.Email = p1.Email
AND p2.Id != p1.Id )
如果您仍然需要更多指导,那么Julia Evans zine也是了解如何使用带有HAVING子句的GROUP BY在表中查找重复元素的好方法
这就是如何使用GROUP BY和HAVING子句在SQL中查找重复电子邮件的全部内容。 我还向您展示了如何使用自我连接和带有EXISTS子句的子查询来解决此问题。 一旦熟悉了模式,就可以解决许多此类问题。 如果您想了解更多信息,请查看以下资源。
感谢您阅读本文,如果您喜欢这篇SQL文章,请与您的朋友和同事分享。 如果您有任何问题或反馈,请留下笔记。