一、表里存在唯一主键,根据多个字段删除重复数据,只保留一条数据
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、添加字段
①表结构添加一个自增且唯一字段
②按照存在唯一主键进行删除重复数据
③删除添加的自增字段