如何删除重复行,但仅针对每个产品id?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (54)

我想删除重复行,但只对每个产品id删除,下面是我的表数据:

在运行DELETE语句之后,结果如下所示:

这是我的查询:

DELETE FROM `test` WHERE name IN (SELECT name FROM `test` GROUP BY name HAVING COUNT(name)>1)
提问于
用户回答回答于

可以用自联接来删除基于相同product_id和name。

delete a
from test a
left join test b on a.product_id = b.product_id
                 and a.name = b.name
                 and a.id > b.id
where b.product_id is not null

代码:http://rextester.com/REUV33630

用户回答回答于
delete t1 from test t1 join test t2 
on t1.name = t2.name and t1.product_id = t2.product_id and t1.id > t2.id;

用这个我可以实现。

做了自我连接来寻找重复值。

所属标签

可能回答问题的人

  • 西风

    renzha.net · 站长 (已认证)

    7 粉丝1 提问8 回答
  • 四无君

    0 粉丝0 提问3 回答
  • o o

    3 粉丝490 提问2 回答
  • Dingda

    Dingda · 站长 (已认证)

    4 粉丝0 提问2 回答

扫码关注云+社区

领取腾讯云代金券