Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)Oracle连接查询有3种:交叉连接、内连接、外连接。交叉连接结果是其他连接结果的超集,外连接结果是内连接结果的超集。接下的例子以departments_v、employees_v两个视图数据为例(4条部门数据,9条人员数据)1.交叉连接:又称笛卡尔积连接,是两个或多个表间的无条件连接,因此它会将表1的每一条数据与表2的每一条数据连接,因此结果会有4*9=36条数据

大家好,又见面了,我是你们的朋友全栈君。

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

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

接下的例子以departments_v、employees_v两个视图数据为例(4条部门数据,9条人员数据)

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

1.交叉连接:又称笛卡尔积连接,是两个或多个表间的无条件连接,因此它会将表1的每一条数据与表2的每一条数据连接,因此结果会有4*9=36条数据

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

2.内连接:根据指定的连接条件进行连接查询,因此满足连接条件的数据才会出现在结果集。

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

当表2扫描一遍后,再从表1的第二条记录开始,从头到尾扫描表2,将符合连接条件的与表1第二条记录连接成结果…

:

直至表1中所有记录处理完毕为止。

Oracle中,内连接的两种写法如下图

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

3.外连接:内连接的基础上,将某个连接表不符合连接条件的记录加入结果集。

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

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

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

下图为【dept表 left join emp表】此时可以把dept表为基准,连接条件为两表部门号相同且部门号为10;

左侧表dept 10号部门的记录 与右侧表emp 10号部门的员工记录 满足连接条件,因此加入结果集;

左侧表dept 20号部门的记录 与右侧表emp 20号部门的员工记录 不满足连接条件,但该查询为左连接,因此会把左侧表dept20号部门的记录加入结果集,右侧表则null填充;

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

下图为【emp表 left join dept表】 可按着上面的情况分析

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

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

【下图为dept表right join emp表】此时可以把emp表为基准,连接条件为两表部门号相同且部门号为10;

右侧表emp 10号部门的员工记录 与左侧表dept 10号部门的记录 满足连接条件,因此加入结果集;

右侧表emp 20号部门的员工记录 与左侧表dept  20号部门的记录 不满足连接条件,但该查询为右连接,因此会把右侧表emp 20号部门的员工记录加入结果集,左侧表则null填充;

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

【下图为emp表right join dept表】可按着上面的情况分析

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

⑵Oracle扩展的连接方式

【下图为dept(+)emp】(右外连接)

【右外连接】在内连接基础上,将连接操作符右侧表不符合连接条件的记录加入结果集中,左侧表则用null填充。

因此可以解析为:连接条件等号哪边的表用null填充,哪边表的列均用(+),另一边的表则会将不符合连接条件的记录加入结果集,如下图的emp表

交换表的顺序为employees_v emp, departments_v dept(此时称为左外连接),但结果一样,只不过结果的列顺序也交换过来,为EMPLOYEE_ID、FIRST_NAME、DEPARTMENT_ID、 DEPARTMENT_ID、DEPARTMENT_NAME

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

【下图为dept emp(+)】(左外连接)

【左外连接】在内连接基础上,将连接操作符左侧表不符合连接条件的记录加入结果集中,右侧表则用null填充。

因此可以解析为:连接条件等号哪边的表用null填充,哪边表的列均用(+),另一边的表则会将不符合连接条件的记录加入结果集,如下图的dept表

交换表的顺序为employees_v emp, departments_v dept(此时称为右外连接),但结果一样,只不过结果的列顺序也交换过来,为EMPLOYEE_ID、FIRST_NAME、DEPARTMENT_ID、 DEPARTMENT_ID、DEPARTMENT_NAME

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

!!!若dept表的列需全加(+),却如下图那样,则不会起作用,仅仅如内连接查询般。

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

4.全外连接:内连接的基础上,将连接操作符两侧表不符合连接条件的记录加入结果集。

全外连接只有标准SQL语句的连接方式表示。

分析:将满足条件的记录选出,再将一侧emp表中不满足连接条件的记录加入结果集,最后将另一侧dept表中不满足连接条件的记录加入结果集。

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

下图为去掉一个条件,分析可按照上图情况推理。

比同样连接条件的【内连接】多了最后一条记录:

Oracle连接查询,彻底搞懂外连接(左外连接&右外连接)

总结:(个人理解方式)

标准SQL语句连接方式:

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

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137819.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月5日 下午9:20
下一篇 2022年5月5日 下午9:20


相关推荐

  • 去除a标签的下划线

    去除a标签的下划线很久没写忘记的差不多了,写下这个方便以后查看,好了话不多说,消除A标签的这么实现呢使用”text-decoration:none;”属性即可:1,一开始是这个样的,是不是有下划线2,下面是我添加了样式的<astyle=”text-decoration:none;”>我们没有下划线</a>结果如下,这样就没有下划线了…

    2022年6月2日
    44
  • Redis的数据过期清除策略 与 内存淘汰策略

    Redis的数据过期清除策略 与 内存淘汰策略

    2021年4月10日
    141
  • Flex 布局详解 – Flex布局的常用属性

    Flex 布局详解 – Flex布局的常用属性文章目录什么是 Flex 布局适用范围使用时应该注意些什么 flex 布局中的一些基本概念容器和项目项目在容器中的显示容器的一些属性 flex direction 属性 flex wrap 属性 flex flow 属性 justify content 属性 align items 属性项目的一些属性 order 属性 flex grow 属性 flex shrink 属性 flex basis 属性 flex 属性 align se

    2026年3月20日
    1
  • 配置管理小报100127:端口

    配置管理小报100127:端口

    2021年8月25日
    72
  • flink入门到项目(完整教程)

    flink入门到项目(完整教程)对 flink 知识点进行简单梳理 及每个功能点的代码实现 本地运行只需要更改 resource conf 下的配置信息 可直接运行 路过的大老爷们 点个星呗 你们的赞是我坚持写下去的动力 项目持续更新中 https github com perkinls flink local train1 知识点梳理 DataStreamAp 代码实现及相关文档 Dat

    2026年3月19日
    2
  • 图像读取的Image.open()和cv2.imread()的区别

    图像读取的Image.open()和cv2.imread()的区别文章目录 1 导入库 2 图像读取 3 读入图片类型 4 通道 5 显示方法 6 相互转换 Image open 和 ci2 imread 都是用来读取的图像 但在使用过程中存在一些差别 具体 可以从以下几个角度进行分析 1 导入库导入的包不同 img cv2 imread path 这是 opencv 中的处理图片的函数 使用时需 importcv2img Image open path 这是 PIL 中的一个处理图片的函数 使用时需 fromPILimpor opencv py

    2026年3月17日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号