- 4
- 0
- 约6.7千字
- 约 6页
- 2021-06-07 发布于湖南
- 举报
……………………………………………………………精品资料推荐…………………………………………………
Oracle 中查找和删除重复记录方法
平时工作中可能会遇到当试图对库表中的某一列或几列创建唯一索引时,系统提示
ORA-01452 :不能创建唯一索引,发现重复记录。
下面总结一下几种查找和删除重复记录的方法(以表 CZ为例):
表 CZ 的结构如下:
SQL desc cz
Name Null? Type
C1 NUMBER(10)
C10 NUMBER(5)
C20 VARCHAR2(3)
删除重复记录的方法原理:
(1). 在 Oracle 中,每一条记录都有一个 rowid ,rowid 在整个数据库中是唯一的, rowid
确定了每条记录是在 Oracle 中的哪一个数据文件、块、行上。
(2). 在重复的记录中,可能所有列的内容都相同,但 rowid 不会相同,所以只要确定
出重复记录中那些具有最大 rowid 的就可以了,其余全部删除。
重复记录判断的标准是:
C1,C10 和 C20这三列的值都相同才算是重复记录。
经查看表 CZ总共有 16 条记录:
SQLset pagesize 100
SQLselect * from cz;
C1 C10 C20
1 2 dsf
1 2 dsf
1 2 dsf
1 2 dsf
2 3 che
1 2 dsf
1 2 dsf
1 2 dsf
1 2 dsf
1
……………………………………………………………精品资料推荐…………………………………………………
2 3 che
2 3 che
2 3 che
2 3 che
3 4 dff
3 4 dff
3 4 dff
4 5 err
5 3 dar
6 1 wee
7 2 zxc
20 rows selected.
1. 查找重复记录的几种方法:
(1).SQLselect * from cz group by c1,c10,c20 having
count(*) 1;
C1 C10 C20
1 2 dsf
2 3 che
3 4 dff
(2).SQLselect distinct * from cz;
C1 C10 C20
1 2 dsf
2 3 che
3 4 dff
(3).SQLselect * from cz a where rowid=(select max(rowid)
原创力文档

文档评论(0)