题目:
编写一个 SQL 查询,查找 Person 表中所有重复的电子邮箱。
示例:
±—±--------+
| Id | Email |
±—±--------+
| 1 | a@b.com |
| 2 | c@d.com |
| 3 | a@b.com |
±—±--------+
根据以上输入,你的查询应返回以下结果:
±--------+
| Email |
±--------+
| a@b.com |
±--------+
说明:所有电子邮箱都是小写字母。
解法1:
select email
from person
group by email
having count(email)>1
解法2:
select email
from
(select count(1) as cnt,email
from person
group by email) r
where r.cnt>1;
解法3:
select distinct a.Email
from Person a, Person b
where a.Email = b.Email
and a.Id != b.Id
本文介绍如何使用三种不同的SQL查询方法来找出Person表中的重复电子邮箱。这些方法包括使用GROUP BY与HAVING子句、子查询以及自我连接等方式。通过这些实例,读者可以了解SQL查询的灵活性,并学会如何处理实际数据中的重复记录。
144

被折叠的 条评论
为什么被折叠?



