-->
编写 SQL 查询以删除名为 Person
的表中的所有重复电子邮件条目,仅保留基于其最小Id 的唯一电子邮件。
+----+------------------+
|身份证 |电子邮件 |
+----+------------------+
| 1 | support@www.sychzs.cn |
| 2 | support@www.sychzs.cn |
| 3 | support@www.sychzs.cn |
+----+------------------+
Id 是该表的主键列。
例如,运行查询后,上面的Person
表应包含以下行:
+----+------------------+
|身份证 |电子邮件 |
+----+------------------+
| 1 | support@www.sychzs.cn |
| 2 | support@www.sychzs.cn |
+----+------------------+
这道题让我们删除重复的邮箱,那我们可以首先查找所有不重复的邮箱,然后取反就是重复的邮箱,都删掉即可,那么我们如何查找所有不重复的邮箱呢,我们可以按照邮箱组起来,然后用Min关键字挑出较小的,然后取补集删除即可:
解决方案1:
从 ID 不在的人员中删除
(SELECT Id FROM (SELECT MIN(Id) Id FROM Person GROUP BY Email) p);
我们还可以使用内部交集将两个表与电子邮件地址关联起来,然后删除具有相同电子邮件地址和大ID的表。请参阅以下代码:
解决方案2:
从人 p1 中删除 p2 加入人 p2
ON www.sychzs.cn = www.sychzs.cn WHERE www.sychzs.cn > www.sychzs.cn;
我们还可以使用where直接连接两个表,而不需要Join:
解决方案三:
从人员 p1、人员 p2 中删除 p2
其中 www.sychzs.cn = www.sychzs.cn AND www.sychzs.cn > www.sychzs.cn;
相似主题:
重复电子邮件
参考:
https://www.sychzs.cn/discuss/61176/simple-solution-using-a-self-join
https://www.sychzs.cn/discuss/48403/my-answer-delete-duplicate-emails-with-double-nested-query
LeetCode All in One 题解汇总(持续更新中...)
-->