C/C++教程

sql-删除重复数据-oracle

本文主要是介绍sql-删除重复数据-oracle,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

删除重复数据

准备重复数据

create table mystudent
(
	stuno number ,
	stuname varchar2(20),
	stuage number 
);
insert into mystudent values(1,'zs',23);
insert into mystudent values(1,'zs',23);

insert into mystudent values(2,'ls',24);
insert into mystudent values(2,'ls',24);

insert into mystudent values(3,'ww',55);

尝试1:distinct

delete from mystudent where stuno in(select distinct stuno from mystudent);
image

数据全部都会被删掉

尝试2:伪列(rowid)

分析
select rowid, s.* from mystudent s;
rowid的组成 AAAST+ AAE AAAAJV AAA:
数据对象号(6位):AAAST+
相关数据文件号(3位):AAE
数据块号(6位):AAAAJV
数据块中行号(3位):AAA

  1. 将重复数据分为一组:
    select min(rowid) from mystudent group by stuno,stuname,stuage ;

  2. 发现数据插入的越晚,rowid越大;数据插入越早,rowid越小。
    image

最终SQL:

delete from mystudent where rowid not in(select min(rowid) from mystudent group by stuno,stuname,stuage);

将相同数据分为一组-->在每组中 找到最小的rowid,即min(rowid) -->删除不是最小的rowid (只保留最初插入的数据) ,即delete from ...not in (...)

这篇关于sql-删除重复数据-oracle的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!