查找重复的mysql记录并使用上一个重复值更新第一个副本

我有一张这样的桌子.

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

我想要做的是对于具有重复TAGS的行,我想用LATEST出现更新FIRST出现的名称.

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

我如何使用PHP与PHP一起做到这一点?或者也许可以在MySQL内部进行?

谢谢!

解决方法:

对于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;
上一篇:mysql – 在几个条件下删除所有重复的主题


下一篇:java – 多个.jar文件中的同一个类文件.这有多糟糕?