mysql删除重复记录/数据
Posted 如月之恒-
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql删除重复记录/数据相关的知识,希望对你有一定的参考价值。
文章目录
单字段去重
表结构如下
sql语句
注意:本例中user_id为主键,user_account为理论上的唯一值,
DELETE
FROM
c_user
WHERE
user_account IN (
SELECT
t.user_account
FROM
(
SELECT
user_account
FROM
c_user
GROUP BY
user_account
HAVING
count(user_account) > 1
) t
)
AND user_id NOT IN (##上面的语句包含所有的重复数据,而此处将最小的值保留
SELECT
t2.userId
FROM
(
SELECT
min(user_id) AS userId
FROM
c_user
GROUP BY
user_account
HAVING
count(1) > 1
) t2
)
多字段去重
表结构如下
根据user_id和role_id来判断数据重复,去除重复数据
sql语句
DELETE FROM c_user_role where c_user_role_id IN
(SELECT c_user_role_id FROM
(select b.* from c_user_role b
where (b.user_id,b.role_id) in (select user_id,role_id from c_user_role group by user_id,role_id having count(*) > 1) ORDER BY user_id desc ) t3
WHERE t3.user_id IN
(
SELECT t1.userId
FROM
(select b.user_id AS userId from c_user_role b
where (b.user_id,b.role_id) in (select user_id,role_id from c_user_role group by user_id,role_id having count(*) > 1)) t1
)
AND t3.c_user_role_id not in(
SELECT
t2.c_user_role_id
FROM
(select max(c_user_role_id) as c_user_role_id from c_user_role group by user_id,role_id having count(*)>1) t2
));
语句分析:
- 先查询出c_user_role的重复数据,不重复的不查询出来。
select b.* from c_user_role b
where (b.user_id,b.role_id) in (select user_id,role_id from c_user_role group by user_id,role_id having count(*) > 1) ORDER BY user_id desc
- 获取有重复数据的user_id
SELECT t1.userId
FROM
(select b.user_id AS userId from c_user_role b
where (b.user_id,b.role_id) in (select user_id,role_id from c_user_role group by user_id,role_id having count(*) > 1)) t1
- 查询出role_id和user_id组合起来的最大值主键,这些查询出来的值做保留(不删除)。
SELECT
t2.c_user_role_id
FROM
(select max(c_user_role_id) as c_user_role_id from c_user_role group by user_id,role_id having count(*)>1) t2
- 这样就可以查出需要删除的c_user_role_id
注意:a.c_user_role_id是主键
mysql表添加别名删除的注意点
反例:
DELETE FROM 表名称 别名 WHERE 别名.列名称 = 值
添加别名删除会出现这样的问题
正确写法
DELETE 别名 FROM 表名称 别名 WHERE 别名.列名称 = 值
注
- 文章是个人知识点整理总结,如有错误和不足之处欢迎指正。
- 如有疑问、或希望与笔者探讨技术问题(包括但不限于本章内容),欢迎添加笔者微信(o815441)。请备注“探讨技术问题”。欢迎交流、一起进步。
以上是关于mysql删除重复记录/数据的主要内容,如果未能解决你的问题,请参考以下文章