Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/58.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何从MySQL表中删除重复行_Mysql_Duplicates - Fatal编程技术网

如何从MySQL表中删除重复行

如何从MySQL表中删除重复行,mysql,duplicates,Mysql,Duplicates,我有一个MySQL表,如: ID, Col1, Col2, Col3, Col4, etc... ID是主键,自表创建以来一直有效 我想做的是删除除一条记录外所有其他列都相同的记录。我会按照MSSQL中的方法来做,但我认为在MySQL中只需稍加修改即可。不可执行,但应指明方向 CREATE TEMPORARY TABLE #Table (Col1, Col2, Col3); INSERT INTO #Table (Col1, Col2, Col3) SELECT DISTINCT Col1,

我有一个MySQL表,如:

ID, Col1, Col2, Col3, Col4, etc...
ID是主键,自表创建以来一直有效


我想做的是删除除一条记录外所有其他列都相同的记录。

我会按照MSSQL中的方法来做,但我认为在MySQL中只需稍加修改即可。不可执行,但应指明方向

CREATE TEMPORARY TABLE #Table (Col1, Col2, Col3);
INSERT INTO #Table (Col1, Col2, Col3) SELECT DISTINCT Col1, Col2, Col3 FROM Table;
DELETE FROM Table;
INSERT INTO Table (Col1, Col2, Col3) SELECT Col1, Col2, Col3 FROM #Table;
DROP TABLE #Table;
你也可以这样做

Create table new_table{id, col1,col2,col3}

insert into new_table values(select distinct * from old_table)

drop table old_table
当然,您必须在所有三个位置将col1、col2扩展到所有列


编辑:我刚从我保存的脚本中提取并重新测试了它,它在MySQL中执行。

您可以使用一些函数(如数据库上的Mindepends)删除除一行之外的所有行。 例:

将表[带重复项的表]重命名为[临时表名]

创建一个与包含重复项的原始表名相同的表

插入[new table]中,从[old table with duplicates]中选择DISTINCT*

删除临时表


没有嵌套的选择或临时表

DELETE  t1
FROM    table_name t1, table_name t2
WHERE   
            (t1.Col1 = t2.Col1 OR t1.Col1 IS NULL AND t2.Col1 IS NULL)
        AND (t1.Col2 = t2.Col2 OR t1.Col2 IS NULL AND t2.Col2 IS NULL)
        AND (t1.Col3 = t2.Col3 OR t1.Col3 IS NULL AND t2.Col3 IS NULL)
        AND (t1.Col4 = t2.Col4 OR t1.Col4 IS NULL AND t2.Col4 IS NULL)
        ...
        AND t1.ID < t2.ID;

您可以在join的帮助下尝试此操作: 就像这样:

DELETE e1 FROM emp_tbl AS e1 JOIN emp_tbl AS e2 WHERE 
e1.Col1=e2.Col1 AND e1.Col2=e2.Col2 AND e1.Col3=e2.Col3 AND e1.Col4=e2.Col4
AND e1.id < e2.id;

您可以运行alter查询并实现以下目的:

ALTER IGNORE TABLE tbl_1
ADD UNIQUE INDEX unq_idx(col1, col2, col3);

我不能保证它会保留副本中的第一条记录,但MySQL通常会这样做。

这不是一个实际的解决方案。适用于pet项目,但在生产环境中很快开始降解。因为有重复项,所以要重命名表吗?如果您有针对旧表运行的代码以及需要更新以匹配新表名的查询,该怎么办?如果我们基于多个条件删除重复项,我认为这是完美的。
DELETE e1 FROM emp_tbl AS e1 JOIN emp_tbl AS e2 WHERE 
e1.Col1=e2.Col1 AND e1.Col2=e2.Col2 AND e1.Col3=e2.Col3 AND e1.Col4=e2.Col4
AND e1.id < e2.id;
ALTER IGNORE TABLE tbl_1
ADD UNIQUE INDEX unq_idx(col1, col2, col3);