我要根据行号(没有主键)删除一些重复的行(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
);


知道我在做什么错吗?非常感谢您的帮助!

最佳答案

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

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


解决方案二:

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

关于mysql - MySQL根据行号删除重复的行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/50586798/

10-10 00:53
查看更多