设为首页 收藏本站
查看: 873|回复: 0

[经验分享] Oracle 外连接和 (+)号的用法

[复制链接]

尚未签到

发表于 2016-7-24 12:06:29 | 显示全部楼层 |阅读模式
  对于外连接,Oracle中可以使用“(+)”来表示,9i可以使用LEFT/RIGHT/FULL OUTER JOIN,下面将配合实例一一介绍。
1. LEFT OUTER JOIN:左外关联
SELECT e.last_name, e.department_id, d.department_name 
FROM employees e 
LEFT OUTER JOIN departments d 
ON (e.department_id = d.department_id); 



等价于
SELECT e.last_name, e.department_id, d.department_name 
FROM employees e, departments d 
WHERE e.department_id=d.department_id(+); 



结果为:所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录。 

2. RIGHT OUTER JOIN:右外关联
SELECT e.last_name, e.department_id, d.department_name 
FROM employees e 
RIGHT OUTER JOIN departments d 
ON (e.department_id = d.department_id); 



等价于
SELECT e.last_name, e.department_id, d.department_name 
FROM employees e, departments d 
WHERE e.department_id(+)=d.department_id; 



结果为:所有员工及对应部门的记录,包括没有任何员工的部门记录。 

3. FULL OUTER JOIN:全外关联
SELECT e.last_name, e.department_id, d.department_name 
FROM employees e 
FULL OUTER JOIN departments d 
ON (e.department_id = d.department_id); 


结果为:所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录和没有任何员工的部门记录。

外连接: 
除了显示匹配相等连接条件的数据外,还可以显示某一个表中无法匹配相等连接条件的记录! 
------------------------------------------------ 
1) 左条件(+) = 右条件 
左条件所在的表必须严格进行相等连接条件的匹配,而右条件所在的表除了匹配相等连接条件外,还可以显示无法匹配连接条件的数据! 
也称为右外连接. 
-------------------------------- 
可以用下列语句取代: 
SELECT...FROM 表1 RIGHT OUTER JOIN 表2 ON 条件; 
2) 左条件 = 右条件(+) 
右条件所在的表必须严格进行相等连接条件的匹配,而左条件所在的表除了匹配相等连接条件外,还可以显示无法匹配连接条件的数据! 
也称为左外连接. 
-------------------------------- 
可以用下列语句取代: 
SELECT...FROM 表1 LEFT OUTER JOIN 表2 ON 条件; 

REM 除了相等连接之外,显示没有员工的部门信息. 
SELECT * FROM EMP,DEPT WHERE EMP.DEPTNO(+) = DEPT.DEPTNO; 
SELECT * FROM EMP RIGHT OUTER JOIN DEPT ON EMP.DEPTNO = DEPT.DEPTNO; 
REM 除了相等连接之外,显示没有部门的员工信息. 
SELECT * FROM EMP,DEPT WHERE EMP.DEPTNO = DEPT.DEPTNO(+); 
SELECT * FROM EMP LEFT OUTER JOIN DEPT ON EMP.DEPTNO = DEPT.DEPTNO;
Oracle 建议你用在From语句后用Outer Join语法 而不是Oracle的Join操作符(+).而且(+)是要受下面的规则限制的,但Outer Join语法则不受的~~ 

1)你不可以在查询块中使用(+) 当它同时包含 join的from语句中 
2)(+)只是在where语句中,并且只能对应一个表或视图的一行字段 
3)如果A和B做联接时有多个条件,那么(+)必须完善所有的匹配条件, 
如果没有 ,oracle不会警告你~只是结果自然不同的 
4)不可以在作出一个表外查询 另张表内查询的(+)联接操作~~ 
5)不可以用(+)外联接到自己 当然Self Join是可以的 
6)含(+)的Where后的注意 
OR不可用 
IN不可用 
子查询不可用 

以下给些个例子:

SQL code


SQL> desc part
Name                                      
Null?    Type
----------------------------------------- -------- -----------------
PART_ID                                   NOT NULL VARCHAR2(4)
SUPPLIER_ID                                       
VARCHAR2(4)
SQL
> select * from part;
PART SUPP
---- ----
P1   S1
P2   S2
P3
P4
SQL
> desc supplier
Name                                      
Null?    Type
----------------------------------------- -------- -----------------
SUPPLIER_ID                               NOT NULL VARCHAR2(4)
SUPPLIER_NAME                             
NOT NULL VARCHAR2(20)
SQL
> select * from supplier;
SUPP SUPPLIER_NAME
---- --------------------
S1   Supplier#1
S2   Supplier#
2
S3   Supplier#
3
SQL
> select p.part_id, s.supplier_name
2  from part p, supplier s
3  where p.supplier_id = s.supplier_id (+);
PART SUPPLIER_NAME
---- --------------------
P1   Supplier#1
P2   Supplier#
2
P3
P4
--(+)是单向的

SQL
> select p.part_id, s.supplier_name
2  from part p, supplier s
3  where p.supplier_id (+) = s.supplier_id (+);
where p.supplier_id (+) = s.supplier_id (+)
*
ERROR at line
3:
ORA
-01468: a predicate may reference only one outer-joined table
--实现Full Join的方法

SQL
> select p.part_id, s.supplier_name
2  from part p, supplier s
3  where p.supplier_id = s.supplier_id (+)
4  union
5  select p.part_id, s.supplier_name
6  from part p, supplier s
7  where p.supplier_id (+) = s.supplier_id;
PART SUPPLIER_NAME
---- --------------------
P1   Supplier#1
P2   Supplier#
2
P3
P4
Supplier#
3
--现在的语法
SQL> select p.part_id, s.supplier_name
2  from part p full outer join supplier s
3  on p.supplier_id = s.supplier_id;
PART SUPPLIER_NAME
---- --------------------
P1   Supplier#1
P2   Supplier#
2
P4
P3
Supplier#
3
另外的EG:
SQL code
SQL
> select * from testa;
ID NAME  ADDR         AGE
---------- ------ ------ ----------
         3 电子   南京           23
5 物理   北京           23
6 物理   河北           25
1 电脑   上海           23
2 电子   北京           22
4 物理   芜湖           22
7 艺术   上海           21
8 歌剧   苏州           16
9 沈亮   上海           22
已选择9行。
SQL
> select * from testb;
ID ADDR
---------- ----------
        7 上海
1 北京
3 上海
5 合肥
--匹配完全
select testa.id,testa.addr from testa,testb where testa.id(+)=testb.id and
testa.addr(
+)=testb.addr;
ID ADDR
---------- ------
         7 上海





现在的Outer Join方法是Oracle9i时开始引用的 ANSI标准的联接语法,现在的则比较直观 简单 
通过上边Full Join的实现方式 不难看到ANSI的联接语法要比用含Union的(+)的执行效率更高~~ 

更详细的解释 请阅读Oracle原版ENGLISH VERSION HELP


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-248614-1-1.html 上篇帖子: Oracle中的日期类型及相关函数 下篇帖子: fc9下oracle sqldeveloper安装日志
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表