1. 内连接(自然连接)

2. 外连接

(1)左外连接 (左边的表不加限制)

(2)右外连接(右边的表不加限制)

(3)全外连接(左右两表都不加限制)

3. 自连接(同一张表内的连接)

SQL的标准语法:

  1. select table1.column,table2.column
  2. from table1 [inner | left | right | full ] join table2 on table1.column1 = table2.column2;

inner join 表示内连接;
left join表示左外连接;
right join表示右外连接;
full join表示完全外连接;
on子句 用于指定连接条件。

注意:

如果使用from子句指定内、外连接,则必须要使用on子句指定连接条件;

如果使用(+)操作符指定外连接,则必须使用where子句指定连接条件。

一. 内连接(Inner Join/Join)

1.1  Inner Join

Inner join逻辑运算符返回满足第一个(顶端)输入与第二个(底端)输入联接的每一行。这个和用select查询多表是一样的效果,所以内连接用的很少。
还有一点要说明的就是Join 默认就是inner join。 所以我们在写内连接的时候可以省略inner 这个关键字。

1.2 下面举例来说明内连接:

1.2.1 先创建2张测试表并插入数据:

  1. SQL> select * from dave;
  2. ID  NAME
  3. ---------- ----------
  4. 1  dave
  5. 2  bl
  6. 1  bl
  7. 2  dave
  8. SQL> select * from bl;
  9. ID  NAME
  10. ---------- ----------
  11. 1  dave
  12. 2  bl

1.2.3 用内链接进行查询:

  1. SQL> Select a.id,a.name,b.name from dave a inner join bl b on a.id=b.id;   -- 标准写法
  2. ID NAME       NAME
  3. ---------- ---------- ----------
  4. 1 dave       dave
  5. 2 bl         bl
  6. 1 bl         dave
  7. 2 dave       bl
  8. SQL> Select a.id,a.name,b.name from dave a join bl b on a.id=b.id;  -- 这里省略了inner 关键字
  9. ID NAME       NAME
  10. ---------- ---------- ----------
  11. 1 dave       dave
  12. 2 bl         bl
  13. 1 bl         dave
  14. 2 dave       bl
  15. SQL> Select a.id,a.name,b.name from dave a,bl b where a.id=b.id;  -- select 多表查询
  16. ID NAME       NAME
  17. ---------- ---------- ----------
  18. 1 dave       dave
  19. 2 bl         bl
  20. 1 bl         dave
  21. 2 dave       bl

从这三个SQL 的结果我们也可以看出,他们的作用是一样的。

1.3 自然连接(Natural join)

自然连接是在两张表中寻找那些数据类型和列名都相同的字段,然后自动地将他们连接起来,并返回所有符合条件按的结果。

先看一下自然连接的例子:

  1. SQL> Select id,name from dave a natural join bl b;
  2. ID NAME
  3. ---------- ----------
  4. 1 dave
  5. 2 bl

这里我们并没有指定连接的条件,实际上oracle为我们自作主张的将,dave表中的id和name字段与bl表中的id和name字段进行了连接。也就是实际上相当于

  1. SQL> Select dave.id,bl.name
  2. From dave join bl on dave.id = bl.id and dave.name=bl.name;
  3. ID NAME
  4. ---------- ----------
  5. 1 dave
  6. 2 bl

因此,我们也可以将自然连接理解为内连接的一种。

有关自然连接的一些注意事项:

(1).如果做自然连接的两个表的有多个字段都满足有相同名称和类型,那么他们会被作为自然连接的条件。

(2).如果自然连接的两个表仅是字段名称相同,但数据类型不同,那么将会返回一个错误。

二. 外连接(Outer Join)

outer join则会返回每个满足第一个(顶端)输入与第二个(底端)输入的联接的行。它还返回任何在第二个输入中没有匹配行的第一个输入中的行。外连接分为三种: 左外连接,右外连接,全外连接。 对应SQL:LEFT/RIGHT/FULL OUTER JOIN。 通常我们省略outer 这个关键字。 写成:LEFT/RIGHT/FULL JOIN。

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

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

1.(+)操作符只能出现在where子句中,并且不能与outer join语法同时使用。

2. 当使用(+)操作符执行外连接时,如果在where子句中包含有多个条件,则必须在所有条件中都包含(+)操作符

3.(+)操作符只适用于列,而不能用在表达式上。

4.(+)操作符不能与or和in操作符一起使用。

5.(+)操作符只能用于实现左外连接和右外连接,而不能用于实现完全外连接。

在做实验之前,我们先将dave表和bl里加一些不同的数据。 以方便测试。

  1. SQL> select * from bl;
  2. ID NAME
  3. ---------- ----------
  4. 1 dave
  5. 2 bl
  6. 3 big bird
  7. 4 exc
  8. 9 怀宁
  9. SQL> select * from dave;
  10. ID NAME
  11. ---------- ----------
  12. 8 安庆
  13. 1 dave
  14. 2 bl
  15. 1 bl
  16. 2 dave
  17. 3 dba
  18. 4 sf-express
  19. 5 dmm

2.1 左外连接(Left outer join/ left join)

left join是以左表的记录为基础的,示例中Dave可以看成左表,BL可以看成右表,它的结果集是Dave表中的数据,在加上Dave表和BL表匹配的数据。换句话说,左表(Dave)的记录将会全部表示出来,而右表(BL)只会显示符合搜索条件的记录。BL表记录不足的地方均为NULL.

示例:

  1. SQL> select * from dave a left join bl b on a.id = b.id;
  2. ID NAME               ID NAME
  3. --------- ---------- ---------- ----------
  4. 1 bl                  1 dave
  5. 1 dave                1 dave
  6. 2 dave                2 bl
  7. 2 bl                  2 bl
  8. 3 dba                 3 big bird
  9. 4 sf-express          4 exc
  10. 5 dmm                             -- 此处B表为null,因为没有匹配到
  11. 8 安庆                             -- 此处B表为null,因为没有匹配到
  12. SQL> select * from dave a left outer join bl b on a.id = b.id;
  13. ID NAME               ID NAME
  14. ---------- ---------- ---------- ----------
  15. 1 bl                  1 dave
  16. 1 dave                1 dave
  17. 2 dave                2 bl
  18. 2 bl                  2 bl
  19. 3 dba                 3 big bird
  20. 4 sf-express          4 exc
  21. 5 dmm
  22. 8 安庆

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

  1. SQL> Select * from dave a,bl b where a.id=b.id(+);    -- 注意: 用(+) 就要用关键字where
  2. ID NAME               ID NAME
  3. ---------- ---------- ---------- ----------
  4. 1 bl                  1 dave
  5. 1 dave                1 dave
  6. 2 dave                2 bl
  7. 2 bl                  2 bl
  8. 3 dba                 3 big bird
  9. 4 sf-express          4 exc
  10. 5 dmm
  11. 8 安庆

2.2 右外连接(right outer join/ right join)

和left join的结果刚好相反,是以右表(BL)为基础的, 显示BL表的所以记录,在加上Dave和BL 匹配的结果。 Dave表不足的地方用NULL填充.

示例:

  1. SQL> select * from dave a right join bl b on a.id = b.id;
  2. ID NAME               ID NAME
  3. ---------- ---------- ---------- ----------
  4. 1 dave                1 dave
  5. 2 bl                  2 bl
  6. 1 bl                  1 dave
  7. 2 dave                2 bl
  8. 3 dba                 3 big bird
  9. 4 sf-express          4 exc
  10. 9 怀宁    --此处左表不足用Null 填充

已选择7行。

  1. SQL> select * from dave a right outer join bl b on a.id = b.id;
  2. ID NAME               ID NAME
  3. ---------- ---------- ---------- ----------
  4. 1 dave                1 dave
  5. 2 bl                  2 bl
  6. 1 bl                  1 dave
  7. 2 dave                2 bl
  8. 3 dba                 3 big bird
  9. 4 sf-express          4 exc
  10. 9 怀宁  --此处左表不足用Null 填充

已选择7行。

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

  1. SQL> Select * from dave a,bl b where a.id(+)=b.id;
  2. ID NAME               ID NAME
  3. ---------- ---------- ---------- ----------
  4. 1 dave                1 dave
  5. 2 bl                  2 bl
  6. 1 bl                  1 dave
  7. 2 dave                2 bl
  8. 3 dba                 3 big bird
  9. 4 sf-express          4 exc
  10. 9 怀宁

2.3 全外连接(full outer join/ full join)

左表和右表都不做限制,所有的记录都显示,两表不足的地方用null 填充。 全外连接不支持(+)这种写法。

示例:

  1. SQL> select * from dave a full join bl b on a.id = b.id;
  2. ID NAME               ID NAME
  3. ---------- ---------- ---------- ----------
  4. 8 安庆
  5. 1 dave                1 dave
  6. 2 bl                  2 bl
  7. 1 bl                  1 dave
  8. 2 dave                2 bl
  9. 3 dba                 3 big bird
  10. 4 sf-express          4 exc
  11. 5 dmm
  12. 9 怀宁

已选择9行。

  1. SQL> select * from dave a full outer join bl b on a.id = b.id;
  2. ID NAME               ID NAME
  3. ---------- ---------- ---------- ----------
  4. 8 安庆
  5. 1 dave                1 dave
  6. 2 bl                  2 bl
  7. 1 bl                  1 dave
  8. 2 dave                2 bl
  9. 3 dba                 3 big bird
  10. 4 sf-express          4 exc
  11. 5 dmm
  12. 9 怀宁

已选择9行。

三. 自连接

自连接(self join)是SQL语句中经常要用的连接方式,使用自连接可以将自身表的一个镜像当作另一个表来对待,从而能够得到一些特殊的数据。

示例:

在oracle的scott的schema中有一个表是emp。在emp中的每一个员工都有自己的mgr(经理),并且每一个经理自身也是公司的员工,自身也有自己的经理。

下面我们需要将每一个员工自己的名字和经理的名字都找出来。这时候我们该怎么做呢?

如果我们有两张这样的表分别教worker和mgr,那么我们就很好写SQL语句。

Select worker.name,

Mgr.name

From worker,mgr

Where worker.id = mgr.id;

但现在我们只有一张emp表。所以我们可以采用自连接。自连接的本意就是将一张表看成多张表来做连接。我们可以这样来写SQL语句:

  1. SQL> select work.ename worker,mgr.ename  manager from scott.emp work, scott.emp mgr
  2. 2  where work.mgr = mgr.empno(+)
  3. 3  order by work.ename;
  4. WORKER     MANAGER
  5. ---------- ----------
  6. ADAMS      SCOTT
  7. ALLEN      BLAKE
  8. BLAKE      KING
  9. CLARK      KING
  10. FORD       JONES
  11. JAMES      BLAKE
  12. JONES      KING
  13. KING                                  --此处右表不足用Null 填充
  14. MARTIN     BLAKE
  15. MILLER     CLARK
  16. SCOTT      JONES
  17. SMITH      FORD
  18. TURNER     BLAKE
  19. WARD       BLAKE

已选择14行。

详解Oracle多种表连接方式的更多相关文章

  1. Oracle多种表连接方式

    1. 内连接(自然连接) 2. 外连接 (1)左外连接 (左边的表不加限制) (2)右外连接(右边的表不加限制) (3)全外连接(左右两表都不加限制) 3. 自连接(同一张表内的连接) SQL的标准语 ...

  2. Oracle的表连接方式

    Oracle的表连接方式: 1.Nl Join连接(嵌套连接) 2.Hash Join(哈希连接) 3.Merge Sort Join(排序合并连接) 各种连接的使用场景: 1. 排序合并连接是偏向于 ...

  3. oracle多表连接方式Hash Join Nested Loop Join Merge Join

    在查看sql执行计划时,我们会发现表的连接方式有多种,本文对表的连接方式进行介绍以便更好看懂执行计划和理解sql执行原理. 一.连接方式:        嵌套循环(Nested  Loops (NL) ...

  4. 数据库基础知识详解三:MVCC、范式以及表连接方式

    写在文章前:本系列文章用于博主自己归纳复习一些基础知识,同时也分享给可能需要的人,因为水平有限,肯定存在诸多不足以及技术性错误,请大佬们及时指正. 8.MVCC 多版本并发控制(Multi-Versi ...

  5. Oracle 表连接方式分析 .

    一 引言 数据仓库技术是目前已知的比较成熟和被广泛采用的解决方案,用于整和电信运营企业内部所有分散的原始业务数据,并通过便捷有效的数据访问手段,可以支持企业内部不同部门,不同需求,不同层次的用户随时获 ...

  6. 看懂Oracle执行计划、表连接方式

    看懂Oracle执行计划  原文:https://www.cnblogs.com/Dreamer-1/p/6076440.html 最近一直在跟Oracle打交道,从最初的一脸懵逼到现在的略有所知,也 ...

  7. [转帖]万字详解Oracle架构、原理、进程,学会世间再无复杂架构

    万字详解Oracle架构.原理.进程,学会世间再无复杂架构 http://www.itpub.net/2019/04/24/1694/ 里面的图特别好 数据和云 2019-04-24 09:11:59 ...

  8. ​ 用一个开发案例详解Oracle临时表

    ​ 用一个开发案例详解Oracle临时表 2016-11-14 bisal ITPUB  一.开发需求  最近有一个开发需求,大致需要先使用主表,或主表和几张子表关联查询出ID(主键)及一些主表字段 ...

  9. 详解Oracle手动创建数据库几大步骤

    在这里我们将介绍Oracle手动创建数据库几大步骤,包括前期的准备工作,以及具体的实施. Oracle手动创建数据库是本文介绍的重点,希望通过本文能帮助大家更好的利用Oracle.51CTO也向您推荐 ...

随机推荐

  1. 分分钟学会GCD

    2014 什么是GCD Grand Central Dispatch (GCD)是异步运行任务的技术之中的一个.一般将应用程序中记述的线程管理用的代码在系统级中实现.因为线程管理是作为系统的一部分来实 ...

  2. Shiro集成Spring

    本篇博客主要讲述的是两者的集成.不涉及到各自的详细细节和功能. 因为官方给出的文档不够具体,对新手而言通过官方文档还不可以非常快的搭建出SpringShiro的webproject.本博客将通过实际的 ...

  3. mongodb 搭建主从服务器

    mongodb 主从配置比较简单,只需要在启动的时候添加参数(-master.-slave -source IP:PORT). Ubuntu 16.04 系统环境 监听端口分别为:27010.2701 ...

  4. elastic search 概念

    1. index 与 type index 相当于 mysql 的 database, type 相当于 table 2. mapping mapping 相当于 mysql table 的列属性声明 ...

  5. 一句话shell

    作者:NetSeek1.删除0字节文件find -type f -size 0 -exec rm -rf {} \; 2.查看进程按内存从大到小排列ps -e -o "%C : %p : % ...

  6. Splash args 属性

    args属性可以获取加载时配置的参数,一般我们只传入URL,如下,args.url 就相当于加载时配置的URL参数,我们把它赋值给 url 变量然后返回:

  7. hadoop关联文件处理

    c001.txt ------------------------------ filetype|commid|commname|addressidcomm|1|罗湖小区1|1comm|2|罗湖小区2 ...

  8. Bootstrap学习总结笔记(24)-- 基于BootstrapValidator的Form表单验证

    Form表单进行数据验证是十分必要的,我们可以自己写JS脚本或者使用JQuery Validate 插件来实现.对于Bootstrap而言,利用BootstrapValidator来做Form表单验证 ...

  9. php文件的处理和操作

    好长时间没有看php手册了,有些关于文件操作方面的知识点发现从没有学过,现补习一下,顺便整理一下: 1.文件的打开:fopen()   此函数的第一个参数含有要打开的文件的名称,第二个参数规定了使用哪 ...

  10. Android设计和开发系列第二篇:Navigation Drawer(Develop)

    Creating a Navigation Drawer THIS LESSON TEACHES YOU TO: Create a Drawer Layout Initialize the Drawe ...