Oracle学习笔记:外连接(+)的用法

  Oracle中常用 left join 和 right join 来进行外连接,同时,oracle也支持 (+) 的特殊用法,也是表示外连接,并且总是放在非主表的一方。

  例如:

  左外连接:

select a.id,b.id 
from a 
left join b 
on a.id = b.id;

  等价于:

select a.id, b.id 
from a,b
where a.id = b.id(+);

  同理,右外连接

select a.id,b.id 
from a 
right join b 
on a.id = b.id;

  等价于:

select a.id, b.id 
from a,b
where a.id(+) = b.id;

  注意:

1.(+)操作符只能出现在WHERE子句中,并且不能与OUTER JOIN语法同时使用。

2.当使用(+)操作符执行外连接时,如果在WHERE子句中包含有多个条件,则必须在所有条件中都包含(+)操作符。

3.(+)操作符只适用于列,而不能用在表达式上。

4.(+)操作符不能与OR和IN操作符一起使用。

5.(+)操作符只能用于实现左外连接和右外连接,而不能用于实现完全外连接。

 

  left/right join 和 (+) 的区别:

 1.效率上没区别

 2.left join 可读性高、功能更全面、通用性强、而且是新标准

 3.建议使用left join


 END 2018-12-18 22:52:22

posted @   Hider1214  阅读(711)  评论(0编辑  收藏  举报
编辑推荐:
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示