oracle删除重复数据保留第一条记录
2. 删除表中多余的重复记录(单个字段),保留
4. 删除表中多余的重复记录(多个字段),保留
5. 查找表中多余的重复记录(多个字段),不包含
发布日期:2025-04-30 01:05:29
浏览次数:14
分类:精选文章
本文共 1111 字,大约阅读时间需要 3 分钟。
数据库中常常会出现重复记录,需要通过特定的方法查找和删除。以下是针对不同场景的处理方法:
1. 查找表中多余的重复记录(单个字段)
如果需要根据单个字段(如Id)判断重复记录,可以使用以下查询方式:
SELECT * FROM 表 WHERE Id IN ( SELECT Id FROM 表 GROUP BY Id HAVING COUNT(Id) > 1);
2. 删除表中多余的重复记录(单个字段),保留ROWID最小的记录
为了删除重复的记录并保留ROWID最小的记录,可以执行以下删除操作:
DELETE FROM 表 WHERE (Id) IN ( SELECT Id FROM 表 GROUP BY Id HAVING COUNT(Id) > 1) AND ROWID NOT IN ( SELECT MIN(ROWID) FROM 表 GROUP BY Id HAVING COUNT(*) > 1);
3. 查找表中多余的重复记录(多个字段)
如果重复记录是基于多个字段(如Id和seq)来判断,可以使用以下查询方式:
SELECT * FROM 表 a WHERE (a.Id, a.seq) IN ( SELECT Id, seq FROM 表 GROUP BY Id, seq HAVING COUNT(*) > 1);
4. 删除表中多余的重复记录(多个字段),保留ROWID最小的记录
为了删除多字段重复记录并保留ROWID最小的记录,可以执行以下删除操作:
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);
5. 查找表中多余的重复记录(多个字段),不包含ROWID最小的记录
如果需要查找多字段重复记录但排除ROWID最小的记录,可以使用以下查询方式:
SELECT * 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);
发表评论
最新留言
第一次来,支持一个
[***.219.124.196]2026年05月24日 10时09分45秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
PHP查找数组中最大值与最小值
2023-03-01
php查最大值,在PHP数组中查找最大值
2023-03-01
php根据年月日计算年龄
2023-03-01
RabbitMQ - 单机部署(超详细)
2023-03-01
php检查注册,PHP检查注册的电子邮件地址是一个’school.edu’地址
2023-03-01
php模拟发送GET和POST请求
2023-03-01
RabbitMQ - 以 MQ 为例,手写一个 RPC 框架 demo
2023-03-01
php模板引擎smarty
2023-03-01
php正则表达式模式
2023-03-01
php正则表达式的特殊字符含义
2023-03-01
PHP正则表达式获取武汉市的实时pm2.5数据并邮件发送phpmailer
2023-03-01
RabbitMQ + JMeter组合,优化你的中间件处理方式!
2023-03-01
PHP水仙花问题解法之一
2023-03-01
php没有解析是怎么回事,linux下php文件没有被剖析怎么办?_后端开发
2023-03-01
php注册页面实现注册后跳转页面
2023-03-01
PHP消息队列的实现方式与详解,值得一看
2023-03-01
PHP混合Go协程并发
2023-03-01
php源码中如何添加滚动公告,给WordPress网站添加滚动公告的方法
2023-03-01
PHP源码安装后如何新增模块
2023-03-01