oracle join分类及用法
在ORACLE数据库中,表与表之间的SQL JOIN方式有多种(不仅表与表,还可以表与视图、物化视图等联结)。SQL JOIN其实是一个逻辑概念,像NEST LOOP JOIN、 HASH JOIN等是表连接的物理实现方式。
为了更直观的了解以上join方式,我们通过俩个测试表来进行测试,首先是建表语句:
内连接:INNER JOIN
inner join 表示返回俩个表或记录连接字段的匹配记录。它有三种实现方式,如下图所示:
注意:inner join 可以使用简写join方式,如下所示,但是建议使用inner join。
用韦恩图来表示则更便于理解:
外链接:OUTER JOIN
1.全连接:full join
全连接:包含左、右俩个表的所有行,不管另一表中是否存在与其匹配的行。不符合条件的,则以空值代替。如下所示:
FULL OUTER JOIN的韦恩图如下:
2.左外连接:LEFT JOIN
左外连接:又叫左连接,意思是包含左边表所有记录,右边所有匹配的记录,如果没有则用空补齐。换句话说就是,列出左边表全部的,及右边表符合条件的,不符合条件的以空值代替。
LEFT OUTER JOIN (with common data)韦恩图如下:
上面是左外连接(带公共数据)的查询方法,那么还有一种就是不包含的,表示如下:
3.右外连接:RIGHT JOIN
右外连接:又叫右链接,意思是包括右边表所有记录,匹配左边表的记录,如果没有则以空补齐。换句话说,列出右边全部的,及左边符合条件的,不符合条件的则以空值代替。
笛卡尔积: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
对于外连接, 也可以使用“(+) ”来表示。 关于使用(+)的一些注意事项:
(+)操作符只能出现在WHERE子句中,并且不能与OUTER JOIN语法同时使用。
当使用(+)操作符执行外连接时,如果在WHERE子句中包含有多个条件,则必须在所有条件中都包含(+)操作符。 ?
(+)操作符只适用于列,而不能用在表达式上。
(+)操作符不能与OR和IN操作符一起使用。
(+)操作符只能用于实现左外连接和右外连接,而不能用于实现完全外连接。
用(+)来实现, 这个+号可以这样来理解: + 表示补充,即哪个表有加号,这个表就是匹配表。如果加号写在右表,左表就是全部显示,所以是左连接。
0条评论