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
相关推荐
松涛和鸣7 分钟前
59、 IMX6ULL按键驱动开发:轮询到中断的实现
linux·服务器·c语言·arm开发·数据库·驱动开发
XT462512 分钟前
创建唯一索引但存在NULL
数据库
扑火的小飞蛾19 分钟前
【Oracle Database 分区表】之新特性_18c(三)
数据库·oracle
九章-23 分钟前
集中式数据库 vs 分布式数据库:2026 最新对比,选哪个更合适?
数据库·分布式·集中式
softshow102628 分钟前
Redis 分布式锁必避问题及解决方案
数据库·redis·分布式
韩立学长36 分钟前
【开题答辩实录分享】以《足球球员数据分析系统开题报告》为例进行选题答辩实录分享
java·数据库·mysql
Gauss松鼠会38 分钟前
【openGauss】openGauss 如何进行数据库例行维护
数据库·sql·database·opengauss
萧咕1 小时前
理解MySQL数据可视化的核心概念
数据库·mysql·信息可视化
wWYy.1 小时前
详解redis(5):Gossiping 协议
数据库·redis·缓存
霖霖总总1 小时前
[小技巧40]MySQL中的MVCC:多版本并发控制的深度解析
数据库·mysql