编写一个 SQL 查询,查找 Person 表中所有重复的电子邮箱。
示例:
+----+---------+
| Id | Email |
+----+---------+
| 1 | a@b.com |
| 2 | c@d.com |
| 3 | a@b.com |
+----+---------+
根据以上输入,你的查询应返回以下结果:
+---------+
| Email |
+---------+
| a@b.com |
+---------+
说明:所有电子邮箱都是小写字母。
答案:
select email , count(email) from Person group by Email
拓展:找相似邮箱:
select email from person where email LIKE "%jiyanjiao@abc.com"
重复邮箱大于等2次的邮箱:
select Email , count(email) from Person group by Email having count(Email) > 1;
说明一下having的用法: sql中的having语句是在使用group by的时候使用的,通常where语句是在group by之前做数据筛选的,而having语句是对group by之后的结果进行筛选的。