Oracle数据库保留一条数据,删除其余重复数据

在工作中遇到一个只保留一条数据,删除其余重复数据的问题,特此记录一下。
qx_ry_gw(人员与岗位的关系表)中,主要有ry_dm(人员代码)gw_dm(岗位代码)字段。

ry_dm(人员代码)gw_dm(岗位代码)lrrq(录入日期)lrr_dm(录入人代码)
ry1gw12023-05-231
ry1gw12023-05-231
ry2gw12023-05-231
ry2gw22023-05-231
ry2gw32023-05-231
ry2gw32023-05-231
ry2gw32023-05-231

可以看到,表中有几条重复数据,现在要对重复数据进行去重,但是要保留一条数据。
删除后的数据应该是这样:

ry_dm(人员代码)gw_dm(岗位代码)lrrq(录入日期)lrr_dm(录入人代码)
ry1gw12023-05-231
ry2gw12023-05-231
ry2gw22023-05-231
ry2gw32023-05-231
那么删除的SQL可以这样写:
delete from qx_ry_gw t 
where (t.ry_dm,t.gw_dm) in 
(select a.ry_dm,a.gw_dm from qx_ry_gw a 
group by a.ry_dm,a.gw_dm 
having count(*) > 1) 
and rowid not in 
(select min(rowid) from qx_ry_gw b 
group by b.ry_dm,b.gw_dm 
having count(*) > 1);

SQL解析:

  1. 根据ry_dm(人员代码)gw_dm(岗位代码),筛选出重复数据;

(t.ry_dm,t.gw_dm) in (select a.ry_dm,a.gw_dm from qx_ry_gw a group by a.ry_dm,a.gw_dm having count(*) > 1)

  1. 排除rowid最小的数据;

and rowid not in (select min(rowid) from qx_ry_gw b group by b.ry_dm,b.gw_dm having count(*) > 1)

  1. 删除筛选后的数据。

delete from qx_ry_gw t

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值