编写一个 SQL 删除语句来 删除 所有重复的电子邮件,只保留一个id最小的唯一电子邮件。
以 任意顺序 返回结果表。 (注意: 仅需要写删除语句,将自动对剩余结果进行查询)
查询结果格式如下所示。
输入:
Person 表:
+----+------------------+
| id | email |
+----+------------------+
| 1 | john@example.com |
| 2 | bob@example.com |
| 3 | john@example.com |
+----+------------------+
输出:
+----+------------------+
| id | email |
+----+------------------+
| 1 | john@example.com |
| 2 | bob@example.com |
+----+------------------+
解释: john@example.com重复两次。我们保留最小的Id = 1。
方法一:用自连接
delete p1 from Person p1,Person p2
where p1.id>p2.id and p1.email=p2.email;
方法二:嵌套
将相同的邮件分组,每组的最小id号不被删除。
将每组最小id选出来做为表p,删除id号不在p中id(即不为最小id)的这一行。
delete from Person
where id not in(select id from(select min(id) as id from Person group by email)p);
注意:where条件句中不能有聚集函数。