oracle删除重复记录

               

 

Author  :  skate

time     :  2007-9-2 0:35


在oracle数据库中,rowid是唯一,他标识记录在哪个文件,块,行上.
在重复的记录上,可能所有的列的内容都是相同的,但他们的rowid
是不同的,所以我只要删除重复记录的最大的rowid就可以,好了理论
说了一堆,还是开始动手吧

1.  删除重复行

SQL> select * from bb;

        ID NAME
---------- ----------
         3 sq
         4 sqa
         5 sqa
         6 sqa
         7 sqa
         2 as
         1 s

已选择7行。

已用时间:  00: 00: 00.00
SQL>

2.  插入重复记录


SQL> insert into bb select * from bb;

已创建7行。

已用时间:  00: 00: 00.00
SQL>


3.  查找重复记录

SQL> select * from bb where rowid!=(
  2  select max(rowid) from bb t
  3     where bb.id=t.id
  4     and   bb.name=t.name);

        ID NAME
---------- ----------
         3 sq
         4 sqa
         5 sqa
         6 sqa
         7 sqa
         2 as
         1 s

已选择7行。

已用时间:  00: 00: 00.03
SQL>

4.  删除重复记录


SQL> delete form bb where rowid!=
  2  ( select max(rowid) from bb t
  3     where bb.id=t.id
  4      and bb.name=t.name);
delete form bb where rowid!=
       *
第 1 行出现错误:
ORA-00942: 表或视图不存在


已用时间:  00: 00: 00.06
SQL> l
  1  delete form bb where rowid!=
  2  ( select max(rowid) from bb t
  3     where bb.id=t.id
  4*     and bb.name=t.name)
SQL> 1
  1* delete form bb where rowid!=
SQL> c/form/from
  1* delete from bb where rowid!=
SQL> l
  1  delete from bb where rowid!=
  2  ( select max(rowid) from bb t
  3     where bb.id=t.id
  4*     and bb.name=t.name)
SQL> /

已删除7行。

已用时间:  00: 00: 00.01
SQL>
 

 

 

到此 工作完毕,很简单吧

 

 

 

网友:dd,指出我的例子有问题,我这里确实有点问题,我的那个实验在SQL> insert into bb select * from bb; 之后没有commit,下面是我完全一样的测试,你看看:

SQL> select * from aa;

        ID NAME
---------- ------------------------------
         1 22
         2 23
         3 24
         4 25

SQL> set term on
SQL> select * from aa;

        ID NAME
---------- ------------------------------
         1 22
         2 23
         3 24
         4 25

SQL> set timi on
SQL> select * from aa;

        ID NAME
---------- ------------------------------
         1 22
         2 23
         3 24
         4 25

已用时间:  00: 00: 00.00
SQL> set feedback on
SQL> select * from aa;

        ID NAME
---------- ------------------------------
         1 22
         2 23
         3 24
         4 25

已选择4行。

已用时间:  00: 00: 00.00
SQL> insert into aa select * from aa;

已创建4行。

已用时间:  00: 00: 00.01
SQL> select * from aa;

        ID NAME
---------- ------------------------------
         1 22
         2 23
         3 24
         4 25
         1 22
         2 23
         3 24
         4 25

已选择8行。

已用时间:  00: 00: 00.01
SQL> commit;

提交完成。

已用时间:  00: 00: 00.00
SQL> select * from aa where rowid !=(select max(rowid) from aa t where bb.id=t.i
d and bb.name=t.name);
select * from aa where rowid !=(select max(rowid) from aa t where bb.id=t.id and
 bb.name=t.name)

 *
第 1 行出现错误:
ORA-00904: "BB"."NAME": 标识符无效


已用时间:  00: 00: 00.03
SQL> select * from aa where rowid !=(select max(rowid) from aa t where aa.id=t.i
d and aa.name=t.name);

        ID NAME
---------- ------------------------------
         1 22
         2 23
         3 24
         4 25

已选择4行。

已用时间:  00: 00: 00.04
SQL> delete  from aa where rowid !=(select  max(rowid) from aa t where aa.id=t.i
d and aa.name=t.name);

已删除4行。

已用时间:  00: 00: 00.01
SQL> commit;

提交完成。

已用时间:  00: 00: 00.00
SQL> select * from aa;

        ID NAME
---------- ------------------------------
         1 22
         2 23
         3 24
         4 25

已选择4行。

已用时间:  00: 00: 00.01
SQL>

这个结果对吧!!!

 

在此感谢网友dd指出错误,谢谢

           
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值