oracle join分类及用法,第1张

  在ORACLE数据库中,与表之间的SQL JOIN方式有多种(不仅表与表,还可以表与视图、物化视图等联结)。SQL JOIN其实是一个逻辑概念,像NEST LOOP JOIN、 HASH JOIN等是表连接的物理实现方式。

oracle join分类及用法,第2张

  为了更直观的了解以上join方式,我们通过俩个测试表来进行测试,首先是建表语句:oracle join分类及用法,第3张

内连接:INNER JOIN

inner join 表示返回俩个表或记录连接字段的匹配记录。它有三种实现方式,如下图所示:

oracle join分类及用法,第4张

注意:inner join 可以使用简写join方式,如下所示,但是建议使用inner join。 

oracle join分类及用法,第5张

用韦恩图来表示则更便于理解:

oracle join分类及用法,第6张

外链接:OUTER JOIN

1.全连接:full join

全连接:包含左、右俩个表的所有行,不管另一表中是否存在与其匹配的行。不符合条件的,则以空值代替。如下所示:

oracle join分类及用法,第7张

 FULL OUTER JOIN的韦恩图如下:

oracle join分类及用法,第8张

2.左外连接:LEFT JOIN

左外连接:又叫左连接,意思是包含左边表所有记录,右边所有匹配的记录,如果没有则用空补齐。换句话说就是,列出左边表全部的,及右边表符合条件的,不符合条件的以空值代替。

oracle join分类及用法,第9张

LEFT OUTER JOIN (with common data)韦恩图如下:

oracle join分类及用法,第10张

上面是左外连接(带公共数据)的查询方法,那么还有一种就是不包含的,表示如下:

oracle join分类及用法,第11张

3.右外连接:RIGHT JOIN
右外连接:又叫右链接,意思是包括右边表所有记录,匹配左边表的记录,如果没有则以空补齐。换句话说,列出右边全部的,及左边符合条件的,不符合条件的则以空值代替。
oracle join分类及用法,第12张

笛卡尔积:CROSS JOIN

cross就是笛卡尔乘积连接,不需要任何关联条件,实现M*N的结果集。实际操作中,很少会用到,但要注意在开发中做表之间关联时应避免产生笛卡尔集,否则数据量过大,导致内存溢出。

总结:

Oracle  外连接(OUTER JOIN)包括以下:

  • 左外连接(左边的表不加限制) left [outer] join,  a.key=b.key(+)

  • 右外连接(右边的表不加限制) righ [outer] join, a.key(+)=b.key

  • 全外连接(左右两表都不加限制) full [outer] join

  • 内连接(左右两表公共部门) [inner] join

  • 笛卡尔积cross join

对于外连接, 也可以使用“(+) ”来表示。 关于使用(+)的一些注意事项:

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

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

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

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

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

用(+)来实现, 这个+号可以这样来理解: + 表示补充,即哪个表有加号,这个表就是匹配表。如果加号写在右表,左表就是全部显示,所以是左连接。

oracle join分类及用法,第13张

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
白度搜_经验知识百科全书 » oracle join分类及用法

0条评论

发表评论

提供最优质的资源集合

立即查看 了解详情