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)。请备注“探讨技术问题”。欢迎交流、一起进步。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值