【问题标题】:Find duplicate mysql record and update first duplicate with last duplicate value查找重复的 mysql 记录并使用最后一个重复值更新第一个重复项
【发布时间】:2011-07-14 18:29:44
【问题描述】:

我有一张这样的桌子。

ID    Name     Tag    
1     Orange   tea     
2     Pear     light    
3     Apple    tea
4     Juice    tea
5     Cocoa    baseball
6     Camera   baseball

我想做的是对于有重复标签的行,我想用最新出现的更新第一次出现的名称。

所以在上面的示例中,我想将 ID 1 的名称从 Orange 更新为 Juice 并删除其他 (#3,#4) 并将 ID 5 从 Cocoa 更新为 Camera 并删除 #6。

我将如何使用 MySQL 和 PHP 来做到这一点?或者也许可以在 MySQL 中完成?

谢谢!

【问题讨论】:

  • 我想我什至不需要删除重复的条目。我只想用最后一个重复的名字更新名字。

标签: mysql duplicates


【解决方案1】:

对于UPDATE 查询,我们需要获取每个标签的最小和最大ID,只有当存在重复行时:

UPDATE table t
  JOIN (
    SELECT MinID, b.Name LatestName
    FROM table b
    JOIN (
      SELECT MIN(ID) MinID, MAX(ID) MaxID
      FROM table
      GROUP BY tag
      HAVING COUNT(*) > 1
    ) g ON b.ID = g.MaxID
  ) rs ON t.ID = rs.MinID
SET t.Name = LatestName;

对于DELETE查询,我们删除所有不是其标签组第一个ID的行:

DELETE t.*
FROM table t
  LEFT JOIN (
    SELECT MIN(ID) MinID
    FROM table
    GROUP BY tag
  ) g ON t.ID = g.MinID
WHERE g.MinID IS NULL;

【讨论】:

    猜你喜欢
    • 2023-03-05
    • 1970-01-01
    • 2017-07-12
    • 2019-07-12
    • 1970-01-01
    • 2013-12-17
    • 2020-07-06
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多