一.概念:

1.多表连接有以下几种分法:

(1)内连接           vs          外连接 (左、右、满)

(2)等值连接        vs         不等值连接

(3)非自连接        vs         自连接

2.笛卡尔集:  所有表中的所有行互相连接

产生条件:(1)多表查询没有连接条件

(2)连接条件无效

3. 内连接   :  结果集中不包含一个表与另一个表不匹配的行

外连接   :  两个表在连接过程中除了返回满足连接条件的行以外(这里的数据是内连接查询到的),还返回左(或右)表中不满足条件的行 ,这种连接称为左(或右) 外连接

满外连接: 返回左表中和右表中不满足条件的行

4.注意:      当列名为多个表共有时,列名必须被限制。

二.1999 语法连接

语法:

FROM    table1
[ CROSS JOIN table2 ] |
[ NATURAL JOIN table2 ] |
[ JOIN table2 USING (column_name) ] | [ JOIN table2
ON (table1.column_name = table2.column_name) ] | [ LEFT | RIGHT | FULL OUTER JOIN table2
ON (table1.column_name = table2.column_name)];

1.join  ...  on...    (推荐使用)

自然连接中是以具有相同名字的列为连接条件的,而 JOIN...ON ...子句并不要求两张表含有相同名字的列。

ON 子句使语句具有更高的易读性。

select  字段...

from  表1   join  表2

on    表1和表2的连接条件
join 表3
on 表1(或表2)和表3的连接条件

(1)两张表的等值连接

select  last_name, department_name
from employees e join departments d
on e.department_id = d.department_id;

(2)使用 join.. on..创建多表连接:三张表的等值连接

select last_name,e.department_id,department_name,city
from employees e join departments d
on e.department_id = d.department_id
join locations l
on d.location_id = l.location_id;

2.CROSS   JOIN        ( 不推荐 )

使用 CROSS   JOIN  会产生叉集,叉集与笛卡尔集相同。

SELECT last_name, department_name
FROM employees
CROSS JOIN departments ;

3.  natural    join   (不推荐)

自然连接:   NATURAL  JOIN 子句,会以两个表中具有相同名字的列为条件创建等值连接。

注:  如果只是列名相同而数据类型不同,则会产生错误。

employees表 和 departments表 有两个相同字段。使用NATURAL  JOIN ,会自动以这两个字段作为连接条件。

select last_name,department_name
from employees natural join departments;

以上代码与下面代码相同:

select last_name,department_name
from employees e,departments d
where e.department_id = d.department_id and e.manager_id = d.manager_id;

4.join .. using ...    (不推荐)

背景:由 NATURAL JOIN 子句创建等值连接,会将这些相同列都作为连接条件。而有时我们只需要其中某些列,这是就可以使用using子句指定等值连接中需要用到的列。

作用:在有多个列满足条件时,可以使用 USING 子句 指定等值连接中需要用到的列。

局限:按照指定的列作为连接条件。但是要求指定的列,在两个表中列名相同。

注:
       不要给选中的列中加上表名前缀或别名。
       JOIN 和 USING 子句经常同时使用。

以上都是内连接

三.外连接

1.左外连接

左外连接:除了查询到满足条件的行之外,返回左表中不满足条件的行。主要有两种实现方式:

(1) left  outer  join... on...

select last_name ,department_name
from employees e left outer join departments d
on e.department_id = d.department_id;

(2) +

select e.employee_id,e.department_id,d.department_name
from employees e,departments d
where e.department_id = d.department_id(+); --左边有,右边没,故右加

2.右外连接

右外连接:返回右表中不满足条件的行。主要有两种实现方式:

(1) right  outer  join... on...

select employee_id,last_name,e.department_id,department_name
from employees e right outer join departments d
on e.department_id = d.department_id;

(2) +

select employee_id,e.department_id,department_name
from employees e,departments d
where e.department_id(+) = d.department_id;

3.满外连接

满外连接:同时返回左表和右表中不满足条件的行

select employee_id,last_name,e.department_id,department_name
from employees e full outer join departments d
on e.department_id = d.department_id;

四.补充

1.自连接

select emp.employee_id,emp.last_name,mgr.last_name
from employees emp,employees mgr
where emp.manager_id = mgr.employee_id;

Oracle学习笔记_04_多表查询的更多相关文章

  1. oracle系列笔记(2)---多表查询

    多表查询     这篇文章主要讲四点: (1)oracle多表查询    (2)SQL99标准的连接查询   (3)子查询     (4)分级查询 oracle多表查询有两种方式,一种是oracle所 ...

  2. Mybatis学习笔记之---多表查询(1)

    Mybatis多表查询(1) (一)举例(用户和账户) 一个用户可以有多个账户 一个账户只能属于一个用户(多个账户也可以属于同一个用户) (二)步骤 1.建立两张表:用户表,账户表,让用户表和账户表之 ...

  3. MySQL学习笔记8——多表查询

    多表查询 多表查询 *合并结果集 *连接查询 *子查询 合并结果集 *要求被合并的表中,列的类型和列数相同(实际上是查询的结果集列类型和列数相同即可) *UNION,去除重复行 *UNION ALL, ...

  4. Mybatis学习笔记之---多表查询(2)

    Mybatis多表查询(2) (一)举例 用户和角色 一个用户可以有多个角色,一个角色可以赋予多个用户 (二)步骤 1.建立两张表:用户表,角色表,让用户表和角色表具有多对多的关系.需要使用中间表,中 ...

  5. MySQL数据库学习笔记----MySQL多表查询之外键、表连接、子查询、索引

    本章主要内容: 一.外键 二.表连接 三.子查询 四.索引 一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复 ...

  6. MySql 在cmd下的学习笔记 —— 有关多表查询的操作(内连接,外连接,交叉连接)

    mysql> create table test5( -> id int, ) -> )engine myisam charset utf8; Query OK, rows affe ...

  7. Oracle学习(五):多表查询

    1.知识点:能够对比以下的录屏进行阅读 SQL> --等值连接 SQL> --查询员工信息: 员工号 姓名 月薪 部门名称 SQL> select empno,ename,sal,d ...

  8. mysql学习笔记--数据库多表查询

    一.内连接[inner join] 1. 语法一:select 列名 from 表1 inner join 表2 on 表1.公共字段=表2.公共字段 2. 语法二:select 列名 from 表1 ...

  9. mysql学习笔记--数据库单表查询

    一.查询语句 1.  select [选项] 列名 [from 表名]  [where 条件]  [order by 排序]  [group by 分组]  [having 条件]  [limit 限 ...

随机推荐

  1. spring+mybatis基于 AOP实现业务日志管理

    最近在项目上用到了操作日志的相关,之前的解决方案就是自己写一个日志project,然后统一调用日志接口即可,这样方便自定义定制,因为有很多设备控制之类的都是需要确认一下的,但是,对数据的操作,比如,增 ...

  2. (转) 对svn分支合并类型和深度的理解

    合并的工作是把主干或者分支上合并范围内的所有改动列出,并对比当前工作副本的内容,由合并者手工修改冲突,然后提交到服务器的相应目录里.如果当前工作副本是主干,则合并的范围是分支上的改动,如果工作副本是分 ...

  3. 四边形不等式优化DP——石子合并问题 学习笔记

    好方啊马上就要区域赛了连DP都不会QAQ 毛子青<动态规划算法的优化技巧>论文里面提到了一类问题:石子合并. n堆石子.现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆石子合并成新的 ...

  4. Github上好的Android开源框架

    1.volley 项目地址 https://github.com/smanikandan14/Volley-demo (1)  JSON,图像等的异步下载: (2)  网络请求的排序(scheduli ...

  5. 执行动态的delphi脚本

    相关资料:https://www.cnblogs.com/linyawen/archive/2011/10/01/2196950.html 如何在程序中执行动态生成的Delphi代码 经常发现有人提这 ...

  6. spring boot ajax post 前后端

    1 传输的数据格式是json 1.1 前端ajax json的所有的key都必须是双引号引用的,并且最外层也要用双引号引用.例如 "{"a":b, "b&quo ...

  7. GCD多线程在swift中的变化

    1.异步线程加载主线程刷新 DispatchQueue.global().async { // TODO:执行异步线程网络请求 DispatchQueue.main.async(execute: { ...

  8. CentOS6下安装PHP7

    更新软件源[1] wget https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm wget http://rpm ...

  9. linux c编程:文件夹操作

    创建目录: 用mkdir函数创建目录: mkdir(const char *pathname, mode_t mode) 参数mode有下列的组合: S_ISUID 04000 文件的执行时设置用户I ...

  10. sublime运行Python

    1.首先安装Python 我这里安装的是Python的3.7版本. 这里有两种安装方式 第一种: 默认路径安装,勾选添加到path复选框(这种情况,sublime可以直接运行Python了) 第二种: ...