当前位置: 首页 > 面试题库 >

删除MySQL表中的重复条目

竺焕
2023-03-14
问题内容

我有一张有几千行的表。该表包含两列,nameemail。我有几个重复的行,例如:

  • John Smith | john@smith.com
  • JJohn Smith | john@smith.com
  • JErica Smith | erica@smith.com
  • JErica Smith | erica@smith.com

删除所有重复结果的最简单方法是什么。例如,使表的内容为= SELECT name, DISTINCT(email) FROM table


问题答案:

您可以很容易地做到这一点,方法是将该查询选择到另一个表中,然后重命名以替换原来的查询。

CREATE TABLE `table2` (
  `name` varchar(255), 
  `email` varchar(255), 
  UNIQUE KEY `email` (`email`));
INSERT INTO `table2` SELECT `name`, DISTINCT(`email`) FROM `table`;
RENAME TABLE `table` TO `table1`;
RENAME TABLE `table2` TO `table`;

请注意,这CREATE应该调整为您的实际表格格式。我在电子邮件字段上添加了唯一密钥,作为有关如何首先防止重复的建议。

或者,您可以遍历此

DELETE FROM `table` 
WHERE `email` IN (
  SELECT `email` FROM `table` GROUP BY `email` HAVING count(*) > 1
) LIMIT 1

这将删除每个呼叫一个重复的记录。限制的重要性是不要删除任何重复的两行



 类似资料:
  • 问题内容: 我想从下表中删除多个重复的键: 希望它像 我正在使用mysql。这是可能的吗?我不能使用 查询来进行唯一的输入,因为我希望将这些重复的输入输入到表中。 问题答案: 一种方法是使用将表联接到子查询上。子查询得到最低为每。当记录在子查询上不匹配时,仅表示它没有匹配的记录并且可以安全地删除。 SQLFiddle演示 但是,如果的记录可以具有不同的名称,则您需要在子句中包括它们,否则将仅保留最

  • 问题内容: 我已向客户提供以下查询,以删除重复的电话号码。记录在MSSQL数据库中,但现在他们也需要在MySQL上进行记录,并且他们报告MySQL抱怨查询的格式。我已经包含了一个测试表的设置,该测试表具有重复的代码示例,但是真正重要的是删除查询。 我在无知和紧急情况下问这个问题,因为我仍在忙于下载和安装MySQL,在此期间也许有人可以提供帮助。 问题答案: 通往罗马的途径很多。这是一。非常快。因此

  • 问题内容: 我有一个关于MySql的问题。我有一个带有7.479.194记录的表。有些记录是重复的。我想这样做: 所以我会取出重复的条目…但是问题是这是大量数据。该表是MyIsam。 这是示例数据-我想按城市,short_ccode进行分组… 我想我必须为my.ini文件修改一些内存,以便按语句分组……哪些设置对此负责? 我有一台具有3bg RAM和2Ghz处理器的机器。 我的ini文件: 问题答

  • 问题内容: 我有一张像这样的桌子: ID为 ,自创建表以来一直在使用。 我想要做的是删除除一个记录以外的所有记录,其中所有其他列都相同。 问题答案: 当然,您必须在所有三个位置将col1,col2扩展到所有列。 编辑:我只是从保留的脚本中重新进行了测试,然后重新测试,它在MySQL中执行。

  • 问题内容: 我有一个注释表,其结构如下: 我有很多重复的评论,名字和电子邮件都一样。我需要删除它们,有人可以建议我如何使用一个查询来实现此目标吗? 谢谢 问题答案:

  • 问题内容: 我有一个包含以下字段的表: 现在,我需要删除具有same的行。一种方法是使用以下SQL以及脚本( ): 运行此查询后,我可以使用服务器端脚本删除重复项。 但是,我想知道是否只能使用SQL查询来完成。 问题答案: 一种简单的方法是在3列上添加索引。在编写语句时,请包含关键字。像这样: 这将删除所有重复的行。作为一项额外的好处,重复的将来会出错。和往常一样,您可能需要在运行类似内容之前进行