LeetCode-196.删除重复的电子邮箱

      发布在:未分类      评论:0 条评论

196.删除重复的电子邮箱

编写一个 SQL 查询,来删除 Person 表中所有重复的电子邮箱,重复的邮箱里只保留 Id 最小 的那个。

+----+------------------+
| Id | Email            |
+----+------------------+
| 1  | john@example.com |
| 2  | bob@example.com  |
| 3  | john@example.com |
+----+------------------+
Id 是这个表的主键。

例如,在运行你的查询语句之后,上面的 Person 表应返回以下几行:

+----+------------------+
| Id | Email            |
+----+------------------+
| 1  | john@example.com |
| 2  | bob@example.com  |
+----+------------------+

提示:


解题:

​ 同一张表需要查询两次可以使用自连接,查询重复的电子邮箱(a.Email = b.Email),重复邮箱只保留Id最小的那个,因为我们删除的是a表,所以(a.Id > b.Id)。

DELETE 
    a
FROM
    Person a,Person b
WHERE
    a.Email = b.Email AND a.Id > b.Id
Responses