外连接:

---外连接并不要求连接的两表的每一条记录在对方表中都有一条匹配记录.要保留所有记录(甚至这条记录没有匹配的记录也要保留)的表成为保留表.外连接可以一句连接表保
留左表,右表和全部表的行二进一步分为左外连接、右外连接、全连接.

(在这种情况下left<左>和right<右>表示Join关键字的两边.)

在标准的SQL语言中,外连接没有隐式的连接符号.

外部连接即包含ON子句又包含WHERE子句时,应当只把表之间的连接条件写在ON子句中,对表中数据的筛选必须写在WHERE子句中.

而内部连接的各条件表达式既可以放在ON子句又可以放在WHERE子句中.

这是因为对外部连接,保留表中被ON子句筛除掉的行要被添加回来,在此操作之后才会用WHERE子句取筛选连接结果中的各行.

左外连接

做外连接(left outer join),简称为左连接(left join) RRREWEQW QEQWQw QWe qWEqwEQWEQWEqweQ jjjkkk

  1. 左外连接会返回左表的所有记录和右表中匹配记录的组合;
  2. 如果右表中无匹配记录,来自于右表的所有列的值设置NULL;
  3. 如果左表的一行在右表中存在多个匹配行,那么左表的行会复制和右表匹配行一样的数量,并进行组合生成连接结果.

eg:

SELECT *
FROM employee
LEFT OUTER JOIN department
ON employee.DepartmentID = department.DepartmentID;

右外连接

SELECT *
FROM employee
RIGHT OUTER JOIN department
ON employee.DepartmentID = department.DepartmentID

显示的右连接很少使用,一般替换成左连接(换换表的位置就可以了),功能相同

SELECT *
FROM department
LEFT OUTER JOIN employee
ON employee.DepartmentID = department.DepartmentID

全连接

全连接是左右外连接的交集.连接表包含被连接的表的所有记录,如果缺少匹配的记录,即以NULL填充.

SELECT *
FROM employee
FULL OUTER JOIN department
ON employee.DepartmentID = department.DepartmentID

Mysql数据库不支持全连接,但可以通过左右外连接的并集(union)来模拟实现.

SELECT *
FROM employee
LEFT JOIN department
ON employee.DepartmentID = department.DepartmentID
UNION
SELECT *
FROM employee
RIGHT JOIN department
ON employee.DepartmentID = department.DepartmentID
WHERE employee.DepartmentID IS NULL

自连接

自连接就是和自身连接

eg:构建一个查询,它试图找到这样的记录:每条记录包含两个雇员,他们来自同一个国家.如果你有两张雇员表(Employee),那么只要第一张表的雇员和第二张表的雇员在同样的国家就行了.你可以用一个铜像的连接(相等连接)操作去得到这个表.不过,这里所有雇员信息都在一张单独的达标例.

employeeID LastName City DepartmentID
111 小紫 上海 31
222 小白 上海 33
333 小蓝 上海 33
444 小黑 广州 34
555 小灰 北京 34
666 小红 北京 NULL

查询所用SQL:

SELECT F.EmployeeID, F.LastName, S.EmployeeID,  S.LastName, F.Country
FROM Employee F, Employee S
WHERE F.City = S.City
AND F.EmployeeID < S.EmployeeID
ORDER BY F.EmployeeID, S.EmployeeID;

通过City自连接后的雇员表(Employee)

EmployeeID LastName EmployeeID LastName City
111 小紫 222 小白 上海
111 小紫 333 小蓝 上海
222 小白 333 小蓝 上海
555 小灰 666 小红 北京

Notes:

  • FS是雇员表的第一个和第二个拷贝的别名

  • 条件F.City = S.City排除了在不同城市的雇员的组合.本实例仅仅期望得到在相同国家的雇员的组合.

  • 条件F.EmployeeID < S.EmployeeID排除了雇员号(EmployeeID)相同的组合.

  • F.EmployeeID < S.EmployeeID排除了重复的组合.没有这个条件,会生成类似下表的无用数据(以北京为例)

    EmployeeID LastName EmployeeID LastName City
    555 小灰 555 小灰 北京
    555 小灰 666 小红 北京
    666 小红 555 小灰 北京
    666 小红 666 小红 北京

    只有中间两行满足初始问题的要求(重复的组合),第一行和最后一项对本例无用,但是在相同的组合的例子中有用

替代方式

外连接查询得到的结果也可以通过关联子查询得到.

eg:

SELECT employee.LastName, employee.DepartmentID,
department.DepartmentName
FROM employee LEFT OUTER JOIN department
ON employee.DepartmentID = department.DepartmentID

or:

SELECT employee.LastName, employee.DepartmentID,
(SELECT department.DepartmentName
FROM department
WHERE employee.DepartmentID = department.DepartmentID )
FROM employee

JOIN中的外连接(external join)的更多相关文章

  1. oracle 内连接(inner join)、外连接(outer join)、全连接(full join)

    转自:https://premier9527.iteye.com/blog/1659689 建表语句: create table EMPLOYEE(EID NUMBER,DEPTID NUMBER,E ...

  2. 外连接OUTER JOIN(三十五)

    外连接OUTER JOIN   LEFT [OUTER] JOIN,左外连接 显示左表的全部记录及右表符合连接条件的记录 下面我们来演示一下,操作命令及部分结果如下: SELECT goods_id, ...

  3. python中列表元素连接方法join用法实例

    python中列表元素连接方法join用法实例 这篇文章主要介绍了python中列表元素连接方法join用法,实例分析了Python中join方法的使用技巧,非常具有实用价值,分享给大家供大家参考. ...

  4. Hibernate中用left join(左外连接)查询映射中没有关联关系的两个表记录问题

    一.问题背景 分账表split_summary结构如下: create table SPLIT_SUMMARY ( uuid VARCHAR2(32) not null, star_tdate VAR ...

  5. 数据库中的左连接(left join)和右连接(right join)区别

    Left Join / Right Join /inner join相关 关于左连接和右连接总结性的一句话: 左连接where只影向右表,右连接where只影响左表. Left Join select ...

  6. EF Linq中的左连接Left Join查询

    linq中的join是inner join内连接,就是当两个表中有一个表对应的数据没有的时候那个关联就不成立. 比如表A B的数据如下 from a in A join b in B on a.BId ...

  7. 清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦

    直入主题: 我们做一个操作,将员工SCOTT的部门去掉,再次通过内连接查看数据,看看会产生什么现象? 使用内连接,查询数据 问题:找不到SCOTT员工了,只有13条数据,这显然不合理:这就是内连接的缺 ...

  8. 【SQL】多表查询中的 外连接 ,on,where

    先简单粗暴给个结论,多表连结查询中,on比where更早起作用,系统首先根据各个表之间的联接条件,把多个表合成一个临时表后,再由where进行匹配过滤,where后语句为真,则能查询出来,而通过外连接 ...

  9. SQL Server中的完全连接(full join)

    一.建库和建表 create database scort use scort create table emp ( empno int primary key, ename ), sal int, ...

随机推荐

  1. python从入门到放弃之协程

    协程 协程,又称微线程,纤程.英文名Coroutine. 协程的概念很早就提出来了,但直到最近几年才在某些语言(如Lua)中得到广泛应用. 子程序,或者称为函数,在所有语言中都是层级调用,比如A调用B ...

  2. [Linux] SSH隧道本地端口转发访问远程服务中的数据库

    当我的本地没有安装任何数据库服务的时候,可以直接通过我本地的端口访问远程机器上的数据库服务,实现这样的效果就可以使用本地转发功能 实际测试本地端口转发,把本地的9006端口转发给远程服务器的115.1 ...

  3. Centos7下安装配置keepalived

    这里用的是两台设备做高可用 master服务器ip地址:192.168.12.78 slave服务器ip地址:192.168.12.79 虚拟ip(VIP,一个尚未占用的内网ip即可)地址:192.1 ...

  4. Linux的启动过程的分析

    Linux的启动过程 Linux系统从启动大哦提供服务的基本过程为:首先机器家电,然后通过MBR或者UEFI装载GRUB,再启动内核,再由内核启动服务,最后开始对外服务 CentOS7要经历四个主要阶 ...

  5. xml的建模

    xml建模的思路 1.分析需要被建模的文件中有那几个对象 2.每个对象拥有的行为以及属性 3.定义对象从小到大(从里到外) 4.通过23种的设计模式中的工厂模式,解析xml生产出指定对象 建模的好处 ...

  6. 04-align-content 它对于当单行是没有效果的

    /* 运用在父级元素上  align-content:   它通产与子元素的div{margin:10px 一起联合使用 }*/ ps==>用在子项出现换行的情况下,并是多行的情况下哦.运用在子 ...

  7. SecureCRT自动断开连接的解决方法

    方法一: 在普通用户下,输入重启sshd服务的命令:service sshd restart 这时会提示:管理系统服务或单元需要身份验证.解决的方法:先要切换为root用户,接着重启sshd服务:se ...

  8. vim考场配置

    syntax on set number set mouse=a set autoread set showmatch set autoindent set smartindent set tabst ...

  9. 201871010110-李华《面向对象程序设计(java)》第十七周学习总结

    博文正文开头格式:(2分) 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.co ...

  10. Python文件读取中:f.seek(0)和f.seek(0,0)有什么区别

    file.seek()方法标准格式是:seek(offset,whence=0)offset:开始的偏移量,也就是代表需要移动偏移的字节数whence:给offset参数一个定义,表示要从哪个位置开始 ...