扫码订阅《 》或入驻星球,即可阅读文章!

GOLANG ROADMAP

阅读模式

  • 沉浸
  • 自动
  • 日常
首页
Go友会
  • 城市
  • 校园
Go学院
  • Go小课
  • Go小考
  • Go实战
  • 精品课
Go求职
  • 求职辅导🔥
  • Offer收割社群
  • 企业题库
  • 面试宝典
Go宝典
  • 在线宝典
  • B站精选
  • 推荐图书
  • 每日博文
Go仓库
实验区
  • Go周边
  • Go下载
  • Go月刊
消息
更多
  • 用户中心

    • 我的信息
    • 推广返利
  • 玩转星球

    • 星球介绍
    • 角色体系
    • 星主权益
  • 支持与服务

    • 联系星主
    • 成长记录
    • 常见问题
    • 吐槽专区
  • 合作交流

    • 渠道合作
    • 课程入驻
    • 友情链接
author-avatar

GOLANG ROADMAP


首页
Go友会
  • 城市
  • 校园
Go学院
  • Go小课
  • Go小考
  • Go实战
  • 精品课
Go求职
  • 求职辅导🔥
  • Offer收割社群
  • 企业题库
  • 面试宝典
Go宝典
  • 在线宝典
  • B站精选
  • 推荐图书
  • 每日博文
Go仓库
实验区
  • Go周边
  • Go下载
  • Go月刊
消息
更多
  • 用户中心

    • 我的信息
    • 推广返利
  • 玩转星球

    • 星球介绍
    • 角色体系
    • 星主权益
  • 支持与服务

    • 联系星主
    • 成长记录
    • 常见问题
    • 吐槽专区
  • 合作交流

    • 渠道合作
    • 课程入驻
    • 友情链接
  • 面试宝典系列

    • SQL 练习
  • 宝典内容

    • 595. Big Countries
    • 627. Swap Salary
    • 620. Not Boring Movies
    • 596. Classes More Than 5 Students
    • 182. Duplicate Emails
    • 196. Delete Duplicate Emails
    • 175. Combine Two Tables
    • 181. Employees Earning More Than Their Managers
    • 183. Customers Who Never Order
    • 184. Department Highest Salary
    • 176. Second Highest Salary
    • 177. Nth Highest Salary
    • 178. Rank Scores
    • 180. Consecutive Numbers
    • 626. Exchange Seats

扫码订阅《 》或入驻星球,即可阅读文章!

196. Delete Duplicate Emails


GOLANG ROADMAP

# Description

邮件地址表:

+----+---------+
| Id | Email   |
+----+---------+
| 1  | john@example.com |
| 2  | bob@example.com |
| 3  | john@example.com |
+----+---------+
1
2
3
4
5
6
7

删除重复的邮件地址:

+----+------------------+
| Id | Email            |
+----+------------------+
| 1  | john@example.com |
| 2  | bob@example.com  |
+----+------------------+
1
2
3
4
5
6

# Solution

只保留相同 Email 中 Id 最小的那一个,然后删除其它的。

连接查询:

DELETE p1
FROM
    Person p1,
    Person p2
WHERE
    p1.Email = p2.Email
    AND p1.Id > p2.Id
1
2
3
4
5
6
7

子查询:

DELETE
FROM
    Person
WHERE
    id NOT IN (
        SELECT id 
        FROM ( 
            SELECT min( id ) AS id 
            FROM Person
            GROUP BY email
        ) AS m
    );
1
2
3
4
5
6
7
8
9
10
11
12

应该注意的是上述解法额外嵌套了一个 SELECT 语句,如果不这么做,会出现错误:You can't specify target table 'Person' for update in FROM clause。以下演示了这种错误解法。

DELETE
FROM
    Person
WHERE
    id NOT IN ( 
        SELECT min( id ) AS id 
        FROM Person 
        GROUP BY email 
    );
1
2
3
4
5
6
7
8
9

参考:pMySQL Error 1093 - Can't specify target table for update in FROM clause (opens new window)

# SQL Schema

与 182 相同。

  • Description
  • Solution
  • SQL Schema