学新通技术网

Mysql 使用SQL直接删除表中重复的数据

叫兽滚粗 23 1

前言

表中出现了重复的数据,因为数据量比较大,所以想直接执行SQL删除,只要使用下面的SQL删除即可

正文

DELETE
FROM
	table_name 
WHERE
	(字段1, 字段2) IN (
		SELECT
			t.字段1,
			t.字段2
		FROM
			(
				SELECT
					字段1,
					字段2
				FROM
					table_name 
				GROUP BY
					字段1,
					字段2
				HAVING
					count(1) > 1
			) t
	)
AND id NOT IN (
	SELECT
		dt.id
	FROM
		(
			SELECT
				min(id) AS id
			FROM
				table_name 
			GROUP BY
				字段1,
				字段2
			HAVING
				count(1) > 1
		) dt
)


 

二、没有主键时删除重复数据


1、创建新表
①创建一个新表与目标表结构字段保持一致
create table new_table_temp
②将过滤查询的统计的数据写入到新表
insert into new_table_temp
③将旧表table_name 删除
delete from table_name 
④将创建的新表名称修改为旧表名称

2、添加字段
①表结构添加一个自增且唯一字段
②按照存在唯一主键进行删除重复数据
③删除添加的自增字段

本文出至:学新通技术网

标签:

评论功能已关闭!!!