oracle join分类及用法

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

oracle join分类及用法_第1张图片

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

内连接:INNER JOIN

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

oracle join分类及用法_第3张图片

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

oracle join分类及用法_第4张图片

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

oracle join分类及用法_第5张图片

外链接:OUTER JOIN

1.全连接:full join

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

oracle join分类及用法_第6张图片

 FULL OUTER JOIN的韦恩图如下:

oracle join分类及用法_第7张图片

2.左外连接:LEFT JOIN

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

oracle join分类及用法_第8张图片

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

oracle join分类及用法_第9张图片

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

oracle join分类及用法_第10张图片

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

笛卡尔积: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分类及用法_第12张图片

你可能感兴趣的:(DB,oracle,分类,数据库)