删除a表中和b表相同的数据

文章作者 100test 发表时间 2008:03:31 11:36:37
来源 100Test.Com百考试题网


软件环境:
1、Windows NT4.0 ORACLE 8.0.4
2、ORACLE安装路径为:C:ORANT
问题提出:
在做数据转储业务的时候,如果发生操作错误,有可能出现主表和副表中都有同一种数据,这样结算的结果就有可能发生错误。


实现方法:
SQL> create table a (
2 bm char(4), --编码
3 mc varchar2(20) --名称
4 )
5 /
表已建立.
SQL> insert into a values(@#1111@#,@#1111@#).
SQL> insert into a values(@#1112@#,@#1111@#).
SQL> insert into a values(@#1113@#,@#1111@#).
SQL> insert into a values(@#1114@#,@#1111@#).
SQL> insert into a values(@#1115@#,@#1111@#).
SQL> create table b as 0select * from a where 1=2.
表已建立.
SQL> insert into b values(@#1111@#,@#1111@#).
SQL> insert into b values(@#1112@#,@#1111@#).
SQL> insert into b values(@#1113@#,@#1111@#).
SQL> insert into b values(@#1114@#,@#1111@#).
SQL> commit.
完全提交.
SQL> 0select * from a.
BM MC
---- --------------------
1111 1111
1112 1111
1113 1111
1114 1111
1115 1111
SQL> 0select * from b.
BM MC
---- --------------------
1111 1111
1112 1111
1113 1111
1114 1111

方法一:exists子句
SQL> 0delete from a where exists (0select @#X@# from b where a.bm=b.bm and a.mc=b.mc).
删除4个记录.
where条件:如果两个表中都拥有相同字段的主键(primary key),则只需比较两个主键就可以了

方法二:in子句
SQL> 0delete from a where (bm,mc) in (0select bm,mc from b).
删除4个记录.
SQL> 0select * from a.
BM MC
---- --------------------
1115 1111
实际测试结论:
在表不是很大时,用in子句速度还可以忍受,而如果记录量很多时(十万条以上),in子句简直让人难以人忍受,速度奇慢。

相关文章


高级复制中如何应对主体站点故障
如何让你的SQL运行得更快
在ORCAL中实现数据库的复制
网络防火墙设计中的重点问题(2)
删除a表中和b表相同的数据
黑客利用PDF邮件附件发起攻击
Windows系统进程完全解析
提高WindowsVista内存效率的优化方法
Vista防火墙性能详细解析
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛