查找重复的电子邮箱(SQL语句)
编写一个 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之后的结果进行筛选的。