我想删除一些重复的行(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
);
知道我在这里做错了什么吗?非常感谢帮助!
答案 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;