美文网首页领扣(leetcode)
197. 删除重复的电子邮箱

197. 删除重复的电子邮箱

作者: 莫小鹏 | 来源:发表于2018-09-23 14:49 被阅读0次

    题目描述

    编写一个 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

    代码

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

    题目链接

    https://leetcode-cn.com/problems/delete-duplicate-emails/description/

    相关文章

      网友评论

        本文标题:197. 删除重复的电子邮箱

        本文链接:https://www.haomeiwen.com/subject/vtxqoftx.html