Oracle去除表重复数据

--1,删除前先查询核实

select b.idcard,b.name,count(b.idcard) num from table1 b group by b.idcard,b.name having count(b.idcard)>1

--1,删除前先查询核实数据量
select count(1) number from table1

--2,删除前请先备份全部数据,避免数据损失。
create table table1备份 as
select * form table1

--3,删除
delete  table1 tt where rowid in

--select * from table1 tt where exists

(select max(rowid) from table1 b group by b.idcard,b.name having count(b.idcard)>1)


--4,在核查数据是否已经处理完毕,操作第一步,第二步核实。

--5,如果有问题请通过第三步的备份表核实数据。

转载于:https://my.oschina.net/u/2336787/blog/485354

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值