mysql删除重复记录/数据

导读:本篇文章讲解 mysql删除重复记录/数据,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

单字段去重

表结构如下

在这里插入图片描述

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/69844.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!