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
相关推荐
he___H11 分钟前
Redis高级数据类型
数据库·redis·缓存
霖霖总总18 分钟前
[小技巧60]深入解析 MySQL Online DDL:MySQL Online DDL、pt-osc 与 gh-ost 机制与最佳实践
数据库·mysql
爱学习的阿磊22 分钟前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
惊讶的猫2 小时前
Redis双写一致性
数据库·redis·缓存
怣502 小时前
[特殊字符] MySQL数据表操作完全指南:增删改查的艺术
数据库·mysql·adb
安然无虞3 小时前
「MongoDB数据库」初见
数据库·mysql·mongodb
一起养小猫3 小时前
Flutter for OpenHarmony 实战:番茄钟应用完整开发指南
开发语言·jvm·数据库·flutter·信息可视化·harmonyos
Mr_Xuhhh3 小时前
MySQL视图详解:虚拟表的创建、使用与实战
数据库·mysql
AI_56783 小时前
MySQL索引优化全景指南:从慢查询诊断到智能调优
数据库·mysql
老虎06273 小时前
Redis入门,配置,常见面试题总结
数据库·redis·缓存