当前位置: 首页 > article >正文

Oracle:左连接、右连接、全外连接、(+)号详解

目录

Oracle 左连接、右连接、全外连接、(+)号详解

1、左外连接(LEFT OUTER JOIN/ LEFT JOIN)

2、右外连接(RIGHT OUTER JOIN/RIGHT JOIN)

3、全外连接(FULL OUTER JOIN/FULL JOIN)

4、补充

5、Oracle中 (+)与left join 的用法区别


Oracle 左连接、右连接、全外连接、(+)号详解

Oracle 外连接 (OUTER JOIN) 分为三种: 左外连接,右外连接,全外连接。left join、right join 和 join 的区别如下:

  • 左外连接(左边的表不加限制)
  • 右外连接(右边的表不加限制)
  • 全外连接(左右两表都不加限制)
  • 连接(左右两表交集)

对应SQL:LEFT/RIGHT/FULL OUTER JOIN。 通常省略OUTER关键字, 写成:LEFT/RIGHT/FULL JOIN。

6ff2cdee1864514f8b2346fe54b1b6e0.png


在左连接和右连接时都会以一张表为基础表,另一张表为补充表,基础表的内容会全部显示,然后再加上两张表匹配的内容。 如果基础表的数据在补充表中没有记录, 那么在相关联的结果集行中补充表列显示为空值(NULL)。

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

  1. (+)操作符只能出现在 WHERE 子句中,并且不能与 OUTER JOIN 语法同时使用。
  2. 当使用(+)操作符执行外连接时,如果在WHERE子句中包含有多个条件,则必须在所有条件中都包含(+)操作符。
  3. (+)操作符只适用于列,而不能用在表达式上。
  4. (+)操作符不能与 OR 和 IN 操作符一起使用。
  5. (+)操作符只能用于实现左外连接和右外连接,而不能用于实现完全外连接。

开始前,先创建两张表,插入数据便于理解测试:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

CREATE TABLE A (

id   number,

name  VARCHAR2(10)

);

CREATE TABLE B (

id   number,

name  VARCHAR2(10)

);

INSERT INTO A VALUES(1,’A1’);

INSERT INTO A VALUES(1,’A2’);

INSERT INTO A VALUES(2,’B1’);

INSERT INTO A VALUES(3,’C1’);

INSERT INTO A VALUES(4,’D1’);

INSERT INTO B VALUES(1,’AA’);

INSERT INTO B VALUES(1,’BB’);

INSERT INTO B VALUES(2,’CC’);

INSERT INTO B VALUES(6,’DD’);

1、左外连接(LEFT OUTER JOIN/ LEFT JOIN)

LEFT JOIN 是以左表的记录为基础表,右表的记录为补充表,示例中A表可以看成左表,B表可以看成右表,它的结果集是A表中的全部数据,再加上A表和B表匹配后的数据。换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录。A表有B表没有的记录对应的B表列显示为NULL。

1

2

3

4

5

6

7

8

9

10

11

SQL> select * from A a left join B b on a.id = b.id;

        ID NAME               ID NAME

————— ————— ————— —————

         1 A2                  1 AA

         1 A1                  1 AA

         1 A2                  1 BB

         1 A1                  1 BB

         2 B1                  2 CC

         4 D1

         3 C1

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

1

select * from A a,B b where a.id=b.id(+);

2、右外连接(RIGHT OUTER JOIN/RIGHT JOIN)

和LEFT JOIN的结果刚好相反,是以右表(B)为基础的。它的结果集是B表所有记录,再加上A和B匹配后的数据。 A表记录不足的地方均为NULL。

1

2

3

4

5

6

7

8

9

10

SQL> select * from A a right join B b on a.id = b.id;

        ID NAME               ID NAME

————— ————— ————— —————

         1 A1                  1 BB

         1 A1                  1 AA

         1 A2                  1 BB

         1 A2                  1 AA

         2 B1                  2 CC

                               6 DD

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

1

select * from A a,B b where a.id(+)=b.id;

3、全外连接(FULL OUTER JOIN/FULL JOIN)

左表和右表都不做限制,所有的记录都显示,两表不足的地方均为NULL。 全外连接不支持(+)写法。

1

2

3

4

5

6

7

8

9

10

11

12

SQL> select * from A a full join B b on a.id = b.id;

        ID NAME               ID NAME

————— ————— ————— —————

         1 A1                  1 BB

         1 A1                  1 AA

         1 A2                  1 BB

         1 A2                  1 AA

         2 B1                  2 CC

         3 C1

         4 D1

                               6 DD

4、补充

1

2

3

4

5

6

7

8

9

SQL> select * from A a,B b where a.id = b.id;

        ID NAME               ID NAME

————— ————— ————— —————

         1 A1                  1 BB

         1 A1                  1 AA

         1 A2                  1 BB

         1 A2                  1 AA

         2 B1                  2 CC

1

2

3

4

5

6

7

8

9

SQL> select * from A a join B b on a.id = b.id;

        ID NAME               ID NAME

————— ————— ————— —————

         1 A1                  1 BB

         1 A1                  1 AA

         1 A2                  1 BB

         1 A2                  1 AA

         2 B1                  2 CC

1

2

3

4

5

6

7

SQL> select * from A a where a.id in (select b.id from B b);

        ID NAME

————— —————

         1 A2

         1 A1

         2 B1

1

2

3

4

5

6

7

SQL> select * from A a where exists (select 1 from B b where a.id = b.id);

        ID NAME

————— —————

         1 A2

         1 A1

         2 B1

5、Oracle中 (+)与left join 的用法区别

1. (+) 写在 where 后面,不能与 or/in 连用, a表是主表,b表是附属表。

select * from a,b where a.id=b.id(+);

2. 左连接写在 from 与where之间,a left join b on a.id=b.id :主表a left join 附表b on 连接条件。

select * from a left join b on a.id=b.id;

3.效率上没区别,left join 可读性高、功能更全面、通用性强、而且是新标准,建议使用left join。


http://www.kler.cn/a/158822.html

相关文章:

  • .NET桌面应用架构Demo与实战|WPF+MVVM+EFCore+IOC+DI+Code First+AutoMapper
  • 删除k8s 或者docker运行失败的脚本
  • WPF Gif图谱 如果隐藏的话会存在BUG
  • PostgreSQL高可用Patroni安装(超详细)
  • Istio分布式链路监控搭建:Jaeger与Zipkin
  • C语言剖析:srand()/rand()/time()
  • 实现Linux SSH免密码登录:使用密钥对进行身份验证
  • Python高级数据结构——树(Tree)
  • File类—递归文件搜索执行脚本文件
  • DFT(离散傅里叶变换)的通俗理解
  • NumPy中,数组的类型是 numpy.ndarray
  • YOLOv5项目实战(5)— 算法模型优化和服务器部署
  • Linux进程间通信之共享内存
  • 【C语言:自定义类型(结构体、位段、共用体、枚举)】
  • 语义分割网络-FCN全卷积网络
  • 安装获取mongodb
  • 【原创】提升MybatisPlus分页便捷性,制作一个属于自己的分页插件,让代码更加优雅
  • 面试问题--Linux网络编程
  • 【数据结构】二叉树的实现
  • 【Qt开发流程】之对象模型2:属性系统
  • 华为OD机试真题-分割均衡字符串-2023年OD统一考试(C卷)
  • PostGIS学习教程九:空间连接
  • Hadoop学习笔记(HDP)-Part.09 安装OpenLDAP
  • Redis高可用集群架构
  • 资料分析(花生)
  • webpack对项目进行优化