Oracle内连接、左外连接、右外连接、全外连接的用法总结

发布时间:2020-06-14编辑:脚本学堂
本文介绍下,在oracle数据库中,实现内连接、左外连接、右外连接、全外连接的方法,通过具体的实例帮助大家理解,有需要的朋友参考下吧。

本节内容:
Oracle数据库的内连接、左外连接、右外连接、全外连接。

数据库版本:Oracle 9i
连接n个表,至少需要n-1个连接条件。例如:连接三个表,至少需要两个连接条件。
表TESTA,TESTB,TESTC,各有A, B两列

oracle数据库的连接也分为两种:内连接与外连接。

A.内连接
内连接,即最常见的等值连接,例:
 

复制代码 代码示例:
SELECT *  
FROM TESTA,TESTB 
WHERE TESTA.A=TESTB.A  

B.外连接
外连接分为左外连接,右外连接和全外连接。
1. 左外连接 left outer join 或者 left join
左外连接就是在等值连接的基础上加上主表中的未匹配数据,例:
 

复制代码 代码示例:
SELECT * 
FROM TESTA  
LEFT OUTER JOIN TESTB  
ON TESTA.A=TESTB.A  

写法2:
 

复制代码 代码示例:
SELECT *  
FROM TESTA,TESTB 
WHERE TESTA.A=TESTB.A(+)  

三个表做左外连接:
 

复制代码 代码示例:
SELECT * 
FROM TESTA  
LEFT OUTER JOIN TESTB  
ON TESTA.A=TESTB.A 
LEFT OUTER JOIN TESTC 
ON TESTA.A=TESTC.A  

写法2:
 

复制代码 代码示例:
SELECT * 
FROM TESTA,TESTB,TESTC 
WHERE TESTA.A=TESTB.A(+) 
AND TESTA.A=TESTC.A(+) 

2. 右外连接 right outer join 或者 right join

右外连接是在等值连接的基础上加上被连接表的不匹配数据
 

复制代码 代码示例:
SELECT * 
FROM TESTA  
RIGHT OUTER JOIN TESTB  
ON TESTA.A=TESTB.A 

写法2:
 

复制代码 代码示例:
SELECT * 
FROM TESTA,TESTB 
WHERE TESTA.A(+)=TESTB.A 

3.全外连接 full outer join 或者 full join

全外连接是在等值连接的基础上将左表和右表的未匹配数据都加上:
 

复制代码 代码示例:
SELECT *  
FROM TESTA  
FULL OUTER JOIN TESTB 
ON TESTA.A=TESTB.A 

全外连接的等价写法,对同一表先做左连接,然后右连接:
 

复制代码 代码示例:
SELECT  TESTA.*,TESTB.* 
FROM TESTA 
LEFT OUTER JOIN TESTB 
ON TESTA.A=TESTB.A 
UNION 
SELECT TESTA.*,TESTB.* 
FROM TESTB 
LEFT OUTER JOIN TESTA 
ON TESTA.A=TESTB.A 

oracle中的各种连接(join):内连接、外连接、自然连接、自连接、交叉连接

内连接(inner join)就是将根据检索条件将满足条件的数据选择出来,oracle首先用第一张表的第一条数据去扫描另一张表的所有数据,如果遇到符合条件的数据就加入到结果集中。直到检索完第二张表的所有数据。

然后,用第一张表的第二条数据,重复刚才的动作,直到以第一张的最后一条数据。其关键字是join,可以使用using关键字和on关键字。oracle中默认的连接是内连接。

外连接(outer join)是根据需要将表中某些不符合选择条件的数据也列举出来,根据选择标准的不同分为左连接、右连接和满外连接。

自然连接(natural join)是由oracle自行决定哪些列作为连接的条件。Oracle是这么确定的:将不同表中的那些具有相同名称和数据类型的字段用相等的条件连接起来。

自连接(self join)中,Oracle将一个表的一个镜像当作另一个表,你可以像使用两个表一样使用这一个表。

交叉连接(cross join)是两个表的笛卡尔积,即不做任何条件限制,他们的结果集的数据的条数是两个表的数据条数的乘积。

在使用关键字JOIN进行不同的表连接时:
-》使用USING子句指定等值连接中需要用到的列;
-》使用ON子句指定额外的连接条件;
-》使用AND增加连接条件;