简述SQL中的“外连接”

1、SQL中外连接分为三种:左外连接、右外连接、全外连接。

2、英文书写格式:

左外连接:LEFT OUTER JOIN(LEFT JOIN);

右外连接:RIGHT OUTER JOIN(RIHT JOIN);

全外连接:FULL OUTER JOIN(FULL JOIN)。

3、简记:

左外连接显示“左边全部的”和“右边与左边相同的”;

右外连接显示“右边全部的”和“左边与右边相同的”;

全外连接显示左、右两边全部的。

4、举例:

(1)查询所有球员及对应球队的记录,包括没有对应球队的球员记录?(处于自由状态的球员暂时不归属于任何球队)

(2)查询所有球员及对应球队的记录,包括没有任何球员的球队记录?(假设因战争等原因而不能组建的某国家队,在表中存有球队信息但是没有对应球员名单)

(3)查询所有球员及对应球队的记录,包括没有任何球员的球队记录,并且包括不归属于任何球队的球员的记录?

5、查询语句:

(1)查询所有球员及对应球队的记录,包括没有对应球队的球员记录?

SELECT p.team_id,p.player_name,t.team_name

FROM playerlist p LEFT OUTER JOIN teamlist t ON(p.team_id=t.team_id);

等价于

SELECT p.team_id,p.player_name,t.team_name

FROM playerlist p,teamlist t WHERE p.team_id=t.team_id(+);

(2)查询所有球员及对应球队的记录,包括没有任何球员的球队记录?

SELECT p.team_id,p.player_name,t.team_name

FROM playerlist p RIGHT OUTER JOIN teamlist t ON(p.team_id=t.team_id);

等价于

SELECT p.team_id,p.player_name,t.team_name

FROM playerlist p,teamlist t WHERE p.team_id(+)=t.team_id;

(3)查询所有球员及对应球队的记录,包括没有任何球员的球队记录,并且包括不归属于任何球队的球员的记录?

SELECT p.team_id,p.player_name,t.team_name

FROM playerlist p FULL OUTER JOIN teamlist t ON(p.team_id=t.team_id);

6、图例

通过图例结合第5点查看SQL语句:

player_list

team_id

player_name

00001

卡卡

00002

贝克汉姆

00004

齐达内

team_list

team_id

team_name

00001

巴西队

00003

卢旺达

00005

伊拉克

查询所有球员及对应球队的记录,包括没有对应球队的球员记录

team_id

player_name

team_name

00001

卡卡

巴西队

00002

贝克汉姆

00004

齐达内

查询所有球员及对应球队的记录,包括没有任何球员的球队记录

team_id

player_name

team_name

00001

卡卡

巴西队

00003

卢旺达

00005

卢森堡

查询所有球员及对应球队的记录,包括没有任何球员的球队记录,并且包括不归属于任何球队的球员的记录

team_id

player_name

team_name

00001

卡卡

巴西队

00002

贝克汉姆

00003

卢旺达

00004

齐达内

00005

卢森堡

***********************************************声明************************************************

原创作品,出自 “深蓝的blog” 博客,欢迎转载,转载时请务必注明出处(http://blog.csdn.net/huangyanlong)。

表述有错误之处,请您留言,不胜感激。

*****************************************************************************************************

补充:

等号在(+)的左侧,为左外连接,左边表数据全部显示;

等号在(+)的右侧,为右外连接,右边表数据全部显示。

简述SQL中的外连接相关推荐

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

    清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦 直入主题: 我们做一个操作,将员工SCOTT的部门去掉,再次通过内连接查看数据,看看会产生什么现象? 使用内连接,查询数据 问 ...

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

    清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦 直入主题: 我们做一个操作,将员工SCOTT的部门去掉,再次通过内连接查看数据,看看会产生什么现象? 使用内连接,查询数据 问 ...

  3. 02-SQL语句给表起别名SQL中的表连接

    什么情况下需要给表起别名? 1.表名比较长 2.当需要在多个表中进行查询并把查询内容同时输出的时候 3.当需要进行表连接的时候(其实和2一个意思,一般情况下多个表进行连接主要目的就是为了从多个表中查询 ...

  4. SQL中的外键约束及多表查询

    SQL中的外键约束及多表查询 外键约束 foreign key 实体:数据库中的表,就可以看作一个实体,实体和实体之间有一些关系 比如说做一个网上商城的项目,里面有用户表,商品表,订单表 一对多的关系 ...

  5. MySQL中的外连接

    MySQL中的外连接 外连接是指查询出符合连接条件的数据同时还包含孤儿数据. 一.孤儿数据 孤儿数据是指被连接的列的值为空的数据. 二.左外连接(left outer join) 左外连接包含左表的孤 ...

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

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

  7. SQL中的各种连接的区别总结(内连接,左连接,左外连接,右连接,右外连接,全连接,全外连接)

    在数据库中建立两张表方便大家理解,teacher和student表(student表中的teacherid字段是对应teacher表中的ID,举个例子张三的老师就是李四,没有teacherid就是这个 ...

  8. SQL中的join连接

    inner join on,full outer join,left join on,right jion on 1.inner join on  内部连接 两表都满足的组合 2.full outer ...

  9. flask sql外键使用_如何在SQL中使用外键?

    flask sql外键使用 Basically, Foreign Key represents relationship between tables. 基本上, 外键代表表之间的关系 . Synta ...

最新文章

  1. 给网站管理员的建议:创建可利用的、可抓取的网站
  2. R绘制发散型条形图(Diverging Bars)
  3. JavaScript异步编程:异步的数据收集方法
  4. 解决“ORA-01036: 非法的变量名/编号“错误
  5. android sdk 更新用的HOSTS
  6. Fabric学习笔记-智能合约
  7. 异步下载圆形进度条显示进度
  8. Git Bash的一些命令和配置
  9. python自定义函数func_python自定义函数与面向对象
  10. 32.Linux/Unix 系统编程手册(上) -- 线程:线程取消
  11. 我开发的内部ORM(一)数据库组件
  12. TARA-威胁建模方案2
  13. 怎么去除视频字幕清理视频字幕或水印的四种方法
  14. hashmap是单向链表吗_LRU(Least Recent Used) java 实现为这么采用HashMap+双向链表
  15. 51单片机(四)—— 51单片机仿真芯片的使用
  16. java 正数减去负数,Java中正数与负数操作、的区别
  17. 变分自编码器和条件变分自编码器 (VAE CVAE)
  18. 国考面试的形式主要有结构化、无领导小组和结构化小组
  19. pythonjson数据解析失败_json解析失败是什么意思
  20. 医院能耗监测管理系统(医院能源管理系统)解决方案

热门文章

  1. 如何在交换机上查找计算机,通过交换机在局域网中查找病毒攻击的方法
  2. 影视剧《少年歌行》开机 优酷出品还原热血江湖
  3. 链游阴阳师:Defina Finance
  4. 怎么把Firefox浏览器设为Windows系统默认浏览器?
  5. 内网ip和外网ip的联系以及连接过程
  6. 三本学计算机还是学土木,浙江哪些三本大学有土木工程专业呀?
  7. 深圳饿了么java工程师_【饿了么 研发工程师JAVA】-Utips校招-你的名企情报站
  8. 命运冠位指定服务器连接中断,《命运-冠位指定》1月23日服务器故障相关情况...
  9. 深度学习网络每一层维度_每个人都可以使用深度学习
  10. conda安装python3.8虚拟环境报错