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