删除表中重复的记录
来源:互联网 发布:static php 编辑:程序博客网 时间:2024/04/30 09:52
问题提出: 当我们想要为一个表创建唯一索引时,如果该表有重复的记录,则无法创建成功。
方法原理:
1、Oracle中,每一条记录都有一个rowid,rowid在整个数据库中是唯一的,
rowid确定了每条记录是在ORACLE中的哪一个数据文件、块、行上。
2、在重复的记录中,可能所有列的内容都相同,但rowid不会相同,所以只要确定出重复记录中
那些具有最大rowid的就可以了,其余全部删除。
3、以下语句用到了3项技巧:rowid、子查询、别名。
实现方法:
SQL> create table a (
2 bm char(4), --编码
3 mc varchar2(20) --名称
4 );
查出重复记录
SQL> select rowid,bm,mc from a where a.rowid!=(select max(rowid) from a b where a.bm=b.bm and a.mc=b.mc);
删除重复记录
SQL> delete from a a where a.rowid!=(select max(rowid) from a b where a.bm=b.bm and a.mc=b.mc);
速度更快的办法:
delete from tab where rowid in (
SELECT rowid FROM tab
minus
SELECT min(rowid) FROM tab
group by col1,col2);
- 查找、删除表中重复的记录
- 如何查找、删除表中重复的记录
- 如何删除表中重复的记录?
- 如何查找、删除表中重复的记录
- 删除表中重复的记录
- 如何查找、删除表中重复的记录
- 删除表中重复的记录
- 删除表中重复的记录
- 删除表中重复的记录!
- 删除表中重复记录的办法
- 删除表中多余的重复记录
- 删除表中重复的记录
- 删除数据库表中重复的记录
- 查询,删除表中重复的记录
- 删除数据库表中重复的记录
- 删除mysql 表中重复的记录
- 删除表中重复记录
- 删除表中重复记录
- glibc、glib和gnulib区别--转帖
- 《HP大中华区总裁孙振耀退休感言》
- 函数指针全解析
- 程序员应该学习一下Python或Ruby
- 《Effective C++》读书笔记之const高效使用
- 删除表中重复的记录
- Concurrent In Java
- Linux:一个人加上一百万人的智慧
- 扩展表分区用
- 事件与委托
- FTP命令详解
- Eclipse Pydev Python Jython IronPython Jpype 的关系
- Unix命令大全
- iOS之多线程编程:三个层次线程应用