oracle删除表中多余的重复记录(多个字段),只留有rowid最小的记录

在Oracle数据库中,你可以使用以下步骤来删除表中多余的重复记录,只留下rowid最小的记录:

首先,确保你已经备份了你的数据,以防万一发生错误。

使用以下查询来找出重复的记录:

SELECT column1, column2, ..., ROWID

FROM your_table

GROUP BY column1, column2, ...

HAVING COUNT(*) > 1;

这将返回所有重复的记录,以及它们的rowid。

  1. 创建一个临时表来保存你想要保留的记录。假设你想要保留每个重复组中rowid最小的记录,你可以执行以下操作:

CREATE TABLE temp_table AS

SELECT column1, column2, ..., MIN(ROWID) AS min_rowid

FROM your_table

GROUP BY column1, column2, ...;

这将创建一个临时表,其中包含你想要保留的记录以及它们的最小rowid。

  1. 删除重复的记录。你可以使用以下查询来删除所有不在临时表中的记录:

DELETE FROM your_table

WHERE ROWID NOT IN (SELECT min_rowid FROM temp_table);

这将删除所有重复的记录,只留下每个重复组中rowid最小的记录。

  1. 最后,你可以选择删除临时表,或者将其保留以备后用。

请注意,在执行这些操作之前,确保你已经备份了你的数据,以防万一发生错误。此外,这些操作可能需要一些时间来执行,具体取决于表的大小和数据的复杂性。

简单的一句SQL:

delete from 表a where (a.Id,a.seq) in (select Id,seq from 表group by Id,seq

having count(*) > 1) and rowid not in (select min(rowid) from 表group by Id,seq

having count(*)>1)

相关推荐
Evan芙3 小时前
RDBMS的库、表、视图、索引、设计范式总结
数据库
一叶飘零_sweeeet3 小时前
从单机到集群:Redis部署全攻略
数据库·redis·缓存
soft20015253 小时前
MySQL Buffer Pool深度解析:LRU算法的完美与缺陷
数据库·mysql·算法
C++业余爱好者3 小时前
SQL Server 中数据库管理系统、数据库实例与数据库的关系与区别
数据库·oracle
保护我方头发丶3 小时前
ESP-wifi-蓝牙
前端·javascript·数据库
tgethe3 小时前
mysql-视图详解
数据库·mysql
漂亮的小碎步丶6 小时前
【6】数据库事务与锁机制详解(附并发结算案例)
数据库·事务·锁机制
北极糊的狐6 小时前
MySQL报错Communications link failure(通信链路失败)
数据库·mysql
合方圆~小文6 小时前
4G定焦球机摄像头综合介绍产品指南
数据结构·数据库·人工智能
zxrhhm6 小时前
数据库中的COALESCE函数用于返回参数列表中第一个非NULL值,若所有参数均为NULL则返回NULL
数据库·postgresql·oracle