当前位置:职场发展 > [LeetCode] 删除重复邮箱 删除重复邮箱

[LeetCode] 删除重复邮箱 删除重复邮箱

  • 发布:2023-10-05 14:25

-->

编写 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 题解汇总(持续更新中...)

-->

相关文章