我有一张这样的桌子.
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;