<span>[LeetCode#182]Duplicate Emails</span>

Write a SQL query to find all duplicate emails in a table named Person.

+----+---------+
| Id | Email   |
+----+---------+
| 1  | a@b.com |
| 2  | c@d.com |
| 3  | a@b.com |
+----+---------+
For example, your query should return the following for the above table:

+---------+
| Email   |
+---------+
| a@b.com |
+---------+
Note: All emails are in lowercase.

本题是找表Person中重复的邮箱,并且该表中的邮箱字母都是小写字母。这道题比较简单,主要涉及到的知识点就是group by 与 having count 的组合,具体的解法如下:

解法一:

SELECT Email from person GROUP BY Email HAVING COUNT(Email)>1;

 

解法二:

  我们可以使用内交来做,用Email来内交两个表,然后返回Id不同的行,则说明两个不同的人使用了相同的邮箱:

SELECT DISTINCT p1.Email FROM person p1 
JOIN person p2 on p1.Email = p2.Email
WHERE p1.Id <> p2.Id;

 

全部评论

相关推荐

路过的周先森:我就喜欢这种无限复活+筛选快的,比那些投进去就没声还占用投递次数的好多了
投递快手等公司7个岗位
点赞 评论 收藏
分享
手机爱睡觉:感觉是没hc了,上次双选hr说七月份就开了招了很多人
投递网易等公司7个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务