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)

相关推荐
hef2883 分钟前
怎么诊断MongoDB Config Server响应极慢的问题_高频Auto-split导致的元库写入压力
jvm·数据库·python
qq_380619168 分钟前
html怎么用deno运行_Deno如何作为本地服务器运行HTML文件
jvm·数据库·python
ruan11451410 分钟前
Redis--个人学习记录
数据库·redis·学习
小红的布丁15 分钟前
BIO、NIO、AIO 与 IO 多路复用:select、poll、epoll 详解
java·数据库·nio
袋鼠云数栈15 分钟前
AI 时代,企业为何必须重新思考数据底座?
数据库·数据治理·数据中台·数栈·袋鼠云
Elastic 中国社区官方博客16 分钟前
在 Elastic 中使用 OpenTelemetry 内容包可视化 OpenTelemetry 数据
大数据·开发语言·数据库·elasticsearch·搜索引擎
Mike117.24 分钟前
GBase 8a UNION 和 UNION ALL 的使用边界
大数据·数据库
u01074754638 分钟前
mysql如何实现高可用集群架构_基于MHA环境搭建与部署
jvm·数据库·python
一 乐44 分钟前
工会管理|基于springboot + vue工会管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·工会管理系统
qq_380619161 小时前
如何在phpMyAdmin中处理特殊字符账号名的授权_反引号的正确包裹
jvm·数据库·python