Oracle SQL子查询中如何使用连接提高性能

教程发布:风哥 教程分类:ITPUX技术网 更新日期:2022-02-12 浏览学习:34

在作表连接(常用于视图)时,常使用以下方法来查询数据:
[mw_shl_code=applescript,true]SELECT PAY_NO, PROJECT_NAME
FROM A
WHERE A.PAY_NO NOT IN (SELECT PAY_
NO FROM B WHERE VALUE >=120000); [/mw_shl_code]
---- 但是若表A有10000条记录,表B有10000条记录,则要用掉30分钟才能查完,主要因为NOT IN要进 行一条一条的比较,共需要10000*10000次比较后,才能得到结果。该用外联接后,可以缩短到1分左右的时间:
[mw_shl_code=applescript,true]SELECT PAY_NO,PROJECT_NAME
FROM A,B
WHERE A.PAY_NO=B.PAY_NO(+)
AND B.PAY_NO IS NULL
AND B.VALUE >=12000; [/mw_shl_code]
################################################################
 在利用import进行数据库重建过程中,有些视图可能会带来问题,因为结构输入的顺序可能造成视图的输入先于它低层次表的输入,这样建立视图就会失败.要解决这一问题,可采取分两步走的方法:首先输入结构,然后输入数据.命令举例如下 (uesrname:jfcl,password:hfjf,host sting:ora1,数据文件:expdata.dmp):
[mw_shl_code=applescript,true]imp jfcl/hfjf@ora1 file=empdata.dmp rows=N
imp jfcl/hfjf@ora1 file=empdata.dmp full=Y buffer=64000
commit=Y ignore=Y [/mw_shl_code]
  第一条命令输入所有数据库结构,但无记录.第二次输入结构和数据,64000字节提交一次.ignore=Y选项保证第二次输入既使对象存在的情况下也能成功.
[mw_shl_code=applescript,true]select a.empno from emp a where a.empno not in (select empno from emp1 where job=’SALE’); [/mw_shl_code]
  倘若利用外部联接,改写命令如下:
[mw_shl_code=applescript,true]select a.empno from emp a ,emp1 b
where a.empno=b.empno(+)
and b.empno is null
and b.job=’SALE’; [/mw_shl_code]
可以发现,运行速度明显提高.

本文标签:
网站声明:本文由风哥整理发布,转载请保留此段声明,本站所有内容将不对其使用后果做任何承诺,请读者谨慎使用!
【上一篇】
【下一篇】