sql-删除重复数据-oracle
2022/6/23 2:21:32
本文主要是介绍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);
数据全部都会被删掉
尝试2:伪列(rowid)
分析
select rowid, s.* from mystudent s;
rowid的组成 AAAST+ AAE AAAAJV AAA:
数据对象号(6位):AAAST+
相关数据文件号(3位):AAE
数据块号(6位):AAAAJV
数据块中行号(3位):AAA
-
将重复数据分为一组:
select min(rowid) from mystudent group by stuno,stuname,stuage ;
-
发现数据插入的越晚,rowid越大;数据插入越早,rowid越小。
最终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的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-24怎么切换 Git 项目的远程仓库地址?-icode9专业技术文章分享
- 2024-12-24怎么更改 Git 远程仓库的名称?-icode9专业技术文章分享
- 2024-12-24更改 Git 本地分支关联的远程分支是什么命令?-icode9专业技术文章分享
- 2024-12-24uniapp 连接之后会被立马断开是什么原因?-icode9专业技术文章分享
- 2024-12-24cdn 路径可以指定规则映射吗?-icode9专业技术文章分享
- 2024-12-24CAP:Serverless?+AI?让应用开发更简单
- 2024-12-23新能源车企如何通过CRM工具优化客户关系管理,增强客户忠诚度与品牌影响力
- 2024-12-23原创tauri2.1+vite6.0+rust+arco客户端os平台系统|tauri2+rust桌面os管理
- 2024-12-23DevExpress 怎么实现右键菜单(Context Menu)显示中文?-icode9专业技术文章分享
- 2024-12-22怎么通过控制台去看我的页面渲染的内容在哪个文件中呢-icode9专业技术文章分享