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
相关推荐
保护我方头发丶2 分钟前
ESP-wifi-蓝牙
前端·javascript·数据库
tgethe8 分钟前
mysql-视图详解
数据库·mysql
漂亮的小碎步丶2 小时前
【6】数据库事务与锁机制详解(附并发结算案例)
数据库·事务·锁机制
北极糊的狐3 小时前
MySQL报错Communications link failure(通信链路失败)
数据库·mysql
合方圆~小文3 小时前
4G定焦球机摄像头综合介绍产品指南
数据结构·数据库·人工智能
zxrhhm3 小时前
数据库中的COALESCE函数用于返回参数列表中第一个非NULL值,若所有参数均为NULL则返回NULL
数据库·postgresql·oracle
小学鸡!3 小时前
DBeaver连接InfluxDB数据库
数据库
running up3 小时前
MyBatis 核心知识点与实战
数据库·oracle·mybatis
薛不痒3 小时前
MySQL中使用SQL语言
数据库·sql·mysql
五阿哥永琪3 小时前
SQL中的函数--开窗函数
大数据·数据库·sql