首页  >  文章  >  数据库  >  如何删除表中的重复行,同时保留最旧的条目?

如何删除表中的重复行,同时保留最旧的条目?

Linda Hamilton
Linda Hamilton原创
2024-10-29 09:21:29230浏览

How to Remove Duplicate Rows in a Table While Keeping the Oldest Entry?

删除重复行,同时保留最旧的条目

在包含用户提交数据的表中,根据subscriberEmail 字段累积了重复条目。为了确保数据完整性,您需要删除这些重复行,同时保留原始提交。

解决方案:

<code class="sql">delete x 
from myTable x
join myTable z on x.subscriberEmail = z.subscriberEmail
where x.id > z.id</code>

说明:

  • 自联接: 查询对 myTable 表执行自联接,创建该表的两个单独的实例,别名为“x”和“z”。
  • 比较条件:连接根据subscriberEmail列匹配“x”和“z”中的行,有效地将每一行与所有其他行进行比较。
  • 过滤: where 子句从“x”中选择 id 列值大于“z”中相应行的 id 值的行。这会识别具有较高 ID 值的重复行。
  • 删除: 删除语句会删除“x”中标识的重复行,只留下原始提交。

其他注意事项:

为了防止将来重复插入,请考虑在subscriberEmail 列上创建一个UNIQUE 索引。这将强制表中电子邮件地址的唯一性。

以上是如何删除表中的重复行,同时保留最旧的条目?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn