gpt4 book ai didi

mysql - 更新主键 - 如果重复,则将其删除

转载 作者:搜寻专家 更新时间:2023-10-30 23:39:02 25 4
gpt4 key购买 nike

我正在尝试从我的主键列中删除空格,如下所示:

update EMAILS set email = TRIM(email);

但是,如果修剪后的电子邮件是重复的,我只想将其删除。有什么办法吗?

最佳答案

没有一个很好的方法来执行您在单个查询中建议的操作,因为 MySQL 并不是真正设计用于适应这样的情况,即初始主键数据在首先被插入之前没有被正确清理。

我的建议是在此更新之前执行单独的查询,以识别并删除这些潜在记录。你可以这样做:

DELETE
FROM emails AS delete
INNER JOIN emails AS original
ON TRIM(delete.email) = original.email
AND delete.email <> original.email

这将从表中删除所有那些在修剪时会导致主键冲突的行。根据表的大小,此查询可能需要一段时间才能运行,因为您将无法利用基于 TRIM() 的 JOIN 条件的索引。

关于mysql - 更新主键 - 如果重复,则将其删除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37486886/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com