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删除重复记录/数据的主要内容,如果未能解决你的问题,请参考以下文章

mysql 删除重复数据

Mysql删除重复记录,保留id最小的一条

MySQL删除重复数据只保留一条

MySQL中删除重复数据只保留一条

MySQL中删除重复数据只保留一条

mysql怎么去除重复数据