Oracle DBA 日常维护--外部联接"+"的用法

       外部联接"+"按其在"="的左边或右边分左联接和右联接.
 
       若不带"+"运算符的表中的一个行不直接匹配于带"+"预算符的表中的任何行,则前者的行与后者中的一个空行相匹配并被返回.
 
        若二者均不带’+’,则二者中无法匹配的均被返回.利用外部联接"+",可以替代效率十分低下的 not in 运算,大大提高运行速度.
 
        例如,下面这条命令执行起来很慢 ,用外联接提高表连接的查询速度.在作表连接(常用于视图)时,常使用以下方法来查询数据: 

SELECT PAY_NO, PROJECT_NAME 
FROM A 
WHERE A.PAY_NO NOT IN (SELECT PAY_ 
NO FROM B WHERE VALUE >=120000); 

     但是若表A有10000条记录,表B有10000条记录,则要用掉30分钟才能查完,主要因为NOT IN要进行一条一条的比较,共需要10000*10000次比较后,才能得到结果。
 
      该用外联接后,可以缩短到1分左右的时间: 

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;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/252936/viewspace-711489/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/252936/viewspace-711489/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值