leetcode196删除重复的电子邮箱

leetcode 196 Delete Duplicate Emails

Posted by BY on September 28, 2020

前言

持续更新了

正文

问题来源

本问题来自leetcode上的196题。

问题描述

编写一个 SQL 查询,来删除 Person 表中所有重复的电子邮箱,重复的邮箱里只保留 Id 最小 的那个。

数据库表

+----+------------------+
| Id | Email            |
+----+------------------+
| 1  | john@example.com |
| 2  | bob@example.com  |
| 3  | john@example.com |
+----+------------------+
Id 是这个表的主键。

查询结果

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

分析:

delete p1 from Person p1 join Person p2 on p1.Email = p2.Email and p1.Id > p2.Id;

总结:

勤思考。

结语

不管怎么样好好加油。