SQL每日一题:删除重复电子邮箱

题干

表: Person

±------------±--------+

| Column Name | Type |

±------------±--------+

| id | int |

| email | varchar |

±------------±--------+

id 是该表的主键列(具有唯一值的列)。

该表的每一行包含一封电子邮件。电子邮件将不包含大写字母。

编写解决方案 删除 所有重复的电子邮件,只保留一个具有最小 id 的唯一电子邮件。

(对于 SQL 用户,请注意你应该编写一个 DELETE 语句而不是 SELECT 语句。)

(对于 Pandas 用户,请注意你应该直接修改 Person 表。)Person 表的最终顺序 无关紧要。返回结果格式如下示例所示。

示例

解答

使用delete和where语句,通过将此表与自身在 Email 列上连接,然后找到具有相同电子邮件地址的其他记录中较大的 id。

sql 复制代码
delete p1 from person p1, person p2 
where p1.email=p2.email and p1.id>p2.id
相关推荐
沐浴露z1 小时前
详解 MySQL 自适应哈希
数据库·mysql·哈希算法
小五Z1 小时前
MySQL--事务
数据库·mysql
小许学java1 小时前
MySQL存储过程
数据库·mysql·存储过程
Elias不吃糖2 小时前
MYSQL指令合集
数据库·mysql
!chen4 小时前
解决 Oracle 监听外网 IP
数据库·tcp/ip·oracle
LBuffer5 小时前
破解入门学习笔记题四十六
数据库·笔记·学习
chase。5 小时前
关于 nvidia-smi: no devices were found 解决方案
服务器·数据库·postgresql
几何心凉5 小时前
openGauss:多核时代企业级数据库的性能与高可用新标杆
前端·数据库·数据库开发
瑞思蕊萌6 小时前
redis实战篇--商品缓存模块
数据库·redis·缓存
AiXed7 小时前
PC微信协议之AES-192-GCM算法
前端·数据库·python