我有一个名为“价格”的表,其结构如下: “id”、“价格”、“availability_id”和“rate_id”。 当用户进行更改时,将写入新记录而不是更新现有记录。我需要做的是删除匹配 'availability_id' 和 'rate_id' 的重复记录,只保留具有最高 'id' 的记录。
我已设法使用以下 MySQL 列出重复项:
select 'id',
`availability_id`,
`rate_id`,
count(*)
from prices
group by 'id',
`availability_id`,
`rate_id`
having count(*) > 1
如果有任何关于删除这些重复项的建议,我将不胜感激。
最佳答案
这样的事情怎么样:
DELETE p1 FROM prices p1, prices p2
WHERE p1.id < p2.id
AND p1.availability_id = p2.availability_id
AND p1.rate_id = p2.rate_id
关于mysql - 删除 MySQL 数据库中的重复条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9870514/