MySQL根据行号删除重复的行

时间:2018-05-29 14:23:46

标签: mysql

我想删除一些重复的行(ID是重复的),基于它的行号(没有主键),这样我就可以将ID列作为主键。

我当前的查询确实返回了我想要删除的正确行:

SELECT *
FROM table_name
WHERE @row_number:=@row_number NOT IN (
    SELECT * FROM (
        SELECT MIN(@row_number:=@row_number) 
        FROM table_name
        GROUP BY id
    ) x
);

但是当我尝试使用以下查询删除它们时,没有任何反应。

DELETE
FROM table_name
WHERE @row_number:=@row_number NOT IN (
    SELECT * FROM (
        SELECT MIN(@row_number:=@row_number) 
        FROM table_name
        GROUP BY id
    ) x
);

知道我在这里做错了什么吗?非常感谢帮助!

1 个答案:

答案 0 :(得分:0)

您可以使用它来设置主键并删除所有重复的ID:

ALTER IGNORE TABLE `table_name` ADD PRIMARY KEY (`id`);

解决方案二:

CREATE TABLE new_table_name AS
SELECT * FROM old_table_name GROUP BY id;