LeetCode196 Delete Duplicate Emails

本贴最后更新于 2568 天前,其中的信息可能已经时移俗易

LeetCode196. Delete Duplicate Emails

题目

Write a SQL query to delete all duplicate email entries in a table named Person, keeping only unique emails based on its smallest Id.

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

Id is the primary key column for this table.
For example, after running your query, the above Person table should have the following rows:

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

题目大意: 删除重复的邮箱,只保留 id 最小的邮箱

解题思路

是否删除这条记录有两个条件
1. 之前存在这个邮箱
2. 之前存在的这个邮箱的 id 比和这条记录的 id 小

由此 使用 EXISTS 即可求解

-- 一开始写成了这样,一直报错 DELETE 能否使用相关子查询?
DELETE FROM Person p1 WHERE Id > (
SELECT min(Id) FROM Person p2 WHERE p1.Email = p2.Email)

DELETE a FROM table a,table b 形式

-- 双表做笛卡尔积 使用相同思路取结果
DELETE p1  
FROM Person p1, Person p2   
WHERE p1.Email=p2.Email AND p1.Id>p2.Id  

NOT IN

先找出不用删除元组的 id 然后删除剩下的 (速度较快)

DELETE FROM Person WHERE Id NOT IN (
    SELECT NOT_DELETE_Id FROM (
        SELECT min(Id) AS NOT_DELETE_Id FROM Person GROUP BY Email  
    ) temp  
);  
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3454 回帖 • 189 关注
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    343 引用 • 723 回帖
  • SQL
    127 引用 • 386 回帖 • 3 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...