Oracle\MySQL连接查询,一次弄清外连接(左&&右)

Oracle连接查询有3种:交叉连接、内连接、外连接。

交叉连接结果是其他连接结果的超集,外连接结果是内连接结果的超集。

接下的例子以departments_v、employees_v两个视图数据为例(4条部门数据,9条人员数据)在这里插入图片描述
1.交叉连接:又称笛卡尔积连接,是两个或多个表间的无条件连接,因此它会将表1的每一条数据与表2的每一条数据连接,因此结果会有4*9=36条数据在这里插入图片描述
2.内连接:根据指定的连接条件进行连接查询,因此满足连接条件的数据才会出现在结果集。

两个表进行内连接查询时,先找到表1的第一条记录,然后从头到尾扫描表2,将符合连接条件的记录与表1第一条记录连接成结果;

当表2扫描一遍后,再从表1的第二条记录开始,从头到尾扫描表2,将符合连接条件的与表1第二条记录连接成结果…
:
直至表1中所有记录处理完毕为止。在这里插入图片描述
3.外连接:在内连接的基础上,将某个连接表不符合连接条件的记录加入结果集。

Oracle中,左外连接、右外连接均有两种连接方式。

⑴先看标准SQL语句连接方式

【左外连接】在内连接基础上,将连接操作符左侧表不符合连接条件的记录加入结果集中,右侧表则用null填充。(个人觉得这更适合解释标准SQL语句的连接方式)在这里插入图片描述
【右外连接】在内连接基础上,将连接操作符右侧表不符合连接条件的记录加入结果集中,左侧表则用null填充。(个人觉得这更适合解释标准SQL语句的连接方式)在这里插入图片描述
4.全外连接:在内连接的基础上,将连接操作符两侧表不符合连接条件的记录加入结果集。

全外连接只有标准SQL语句的连接方式表示。
分析:将满足条件的记录选出,再将一侧emp表中不满足连接条件的记录加入结果集,最后将另一侧dept表中不满足连接条件的记录加入结果集。在这里插入图片描述
下图为去掉一个条件,分析可按照上图情况推理。

比同样连接条件的【内连接】多了最后一条记录在这里插入图片描述
标准SQL语句连接方式:

【A left join B】left join即把左边表A当作基准。在内连接操作方式下,遇到符合连接条件的记录加入结果集,遇到A中不符合条件的记录也加入(因为它是标准),但对应B表的记录用null填充;

【A right join B】right join即把右边表B当作基准。在内连接操作方式下,遇到符合连接条件的记录加入结果集,遇到B中不符合条件的记录也加入(因为它是标准),但对应A表的记录用null填充;

oracle扩展连接方式:连接条件哪边表的列用(+),则它的记录用null值填充(也可把null当作占位符一样,没有东西空占着位置),另一边的表就是会把不符合连接条件的记录也加进查询结果中。
同时外连接还有嵌套循环或hash连接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值