美文网首页MySQL
(LeetCode196:数据库)删除重复的电子邮箱

(LeetCode196:数据库)删除重复的电子邮箱

作者: lconcise | 来源:发表于2018-09-08 11:12 被阅读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  |
    +----+------------------+
    

    Solution:

    DELETE a
    FROM
        person a,
        person b
    WHERE
        a.email = b.email
    AND a.id > b.id;
    

    相关文章

      网友评论

        本文标题:(LeetCode196:数据库)删除重复的电子邮箱

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