对于Oracle,MySQL,SQL Server重复数据删除

问题前提

之前做过数据入湖,建表的时候匆忙,没有做主键,导致入湖出现了重复数据。举个例子:

|----|------|-----|-----|
| id | name | age | sex |
| 1 | 用户1 | 21 | 男 |
| 1 | 用户1 | 21 | 男 |
| 1 | 用户1 | 21 | 男 |

存在了如上两条及两条数据,目的是要去除重复数据,只保留一条,从而设置id为主键。

Oracle

Oracle如果存在重复数据,id设置主键时,会有02437报错。

对于Oracle去处重复数据是最简单的,每行自带rowid。

sql 复制代码
DELETE 
FROM
	user 
WHERE
	id IN ( SELECT id FROM user GROUP BY id HAVING count( id ) > 1 ) 
	AND rowid NOT IN (
	SELECT
		min( rowid ) 
	FROM
		user  
	GROUP BY
		id 
HAVING
	count( id )> 1)

执行如上语句即可删除重复数据。

因为本地没有Oracle数据库,就不做演示了。

MySQL

MySQL没有rowid,那么MySQL解决办法只有一种,把A表的数据去重添加到B表中,在B表中设置id为主键,最后把B表重命名为A表。

sql 复制代码
INSERT INTO user1 ( SELECT DISTINCT * FROM user );

暂不清楚,数据量大的情况下会不会出现崩溃,可以通过limit截取。

如果不确定A表的数据是否全部添加到B表,可以添加完成后,执行

sql 复制代码
DELETE FROM user WHERE user.id IN (SELECT user1.id FROM user1)

这种方式当然也适用于其他数据库。

当然MySQL还有另外一种方式,就是新增一个字段为自增字段且不为null,让其自动填充,类似充当Orcal中的rowid。

填充完成后。

sql 复制代码
DELETE 
FROM
	user 
WHERE
	user.rowid NOT IN (
	  SELECT
		dt.minid 
	  FROM
	  ( SELECT MIN( user.rowid ) AS minid FROM user GROUP BY name ) dt 
	)

有多种方式,可参考【mysql】mysql删除重复记录并且只保留一条_mysql删除完全重复数据只保留一条_千g的博客-CSDN博客

SQL Server

SQL Server 和MySQL逻辑是一样的,但语法上稍有变化

sql 复制代码
SELECT DISTINCT * INTO [dbo].[user1] FROM [dbo].[user]

SQL Server是不需要创建user1表的,会自动创建,数据导入到新表后再设置主键即可。

另外一种设置自增rowid,执行:

sql 复制代码
DELETE 
FROM
	[dbo].[user] 
WHERE
	[dbo].[user].rowid NOT IN (
	  SELECT
		dt.minid 
	  FROM
	  ( SELECT MIN( [dbo].[user].rowid ) AS minid FROM [dbo].[user] GROUP BY name ) dt 
	)

后续

后续研究其他数据库,mongo等其他用到的数据库再做更新,

相关推荐
一个天蝎座 白勺 程序猿几秒前
Apache IoTDB(10):数据库操作——从查询到优化的全链路实践指南
数据库·apache·时序数据库·iotdb
q***57747 分钟前
MySQL 实验1:Windows 环境下 MySQL5.5 安装与配置
windows·mysql·adb
普普通通的南瓜26 分钟前
IP证书在关键信息基础设施安全防护中的实践与挑战
网络·数据库·网络协议·tcp/ip·安全·ssl
合作小小程序员小小店37 分钟前
桌面开发,超市管理系统开发,基于C#,winform,sql server数据库
开发语言·数据库·sql·microsoft·sqlserver·c#
quweiie44 分钟前
thinkphp8.0链接SQL SERVER2022数据库
数据库·sqlserver·thinkphp
8***84821 小时前
如何在Linux中找到MySQL的安装目录
linux·运维·mysql
Databend1 小时前
如何打造AI时代的数据基石 | Databend Meetup 上海站
数据库
W***83202 小时前
如何在 Ubuntu 22.04 上安装 MySQL
linux·mysql·ubuntu
老华带你飞2 小时前
海产品销售系统|海鲜商城购物|基于SprinBoot+vue的海鲜商城系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·海鲜商城购物系统
合作小小程序员小小店2 小时前
桌面开发,在线%超市销售管理%系统,基于vs2022,c#,winform,sql server数据
开发语言·数据库·microsoft·c#