简述SQL中的外连接
简述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中的外连接相关推荐
- oracle 哦【的【,清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦
清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦 直入主题: 我们做一个操作,将员工SCOTT的部门去掉,再次通过内连接查看数据,看看会产生什么现象? 使用内连接,查询数据 问 ...
- mysql与orancl_清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦
清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦 直入主题: 我们做一个操作,将员工SCOTT的部门去掉,再次通过内连接查看数据,看看会产生什么现象? 使用内连接,查询数据 问 ...
- 02-SQL语句给表起别名SQL中的表连接
什么情况下需要给表起别名? 1.表名比较长 2.当需要在多个表中进行查询并把查询内容同时输出的时候 3.当需要进行表连接的时候(其实和2一个意思,一般情况下多个表进行连接主要目的就是为了从多个表中查询 ...
- SQL中的外键约束及多表查询
SQL中的外键约束及多表查询 外键约束 foreign key 实体:数据库中的表,就可以看作一个实体,实体和实体之间有一些关系 比如说做一个网上商城的项目,里面有用户表,商品表,订单表 一对多的关系 ...
- MySQL中的外连接
MySQL中的外连接 外连接是指查询出符合连接条件的数据同时还包含孤儿数据. 一.孤儿数据 孤儿数据是指被连接的列的值为空的数据. 二.左外连接(left outer join) 左外连接包含左表的孤 ...
- 清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦
直入主题: 我们做一个操作,将员工SCOTT的部门去掉,再次通过内连接查看数据,看看会产生什么现象? 使用内连接,查询数据 问题:找不到SCOTT员工了,只有13条数据,这显然不合理:这就是内连接的缺 ...
- SQL中的各种连接的区别总结(内连接,左连接,左外连接,右连接,右外连接,全连接,全外连接)
在数据库中建立两张表方便大家理解,teacher和student表(student表中的teacherid字段是对应teacher表中的ID,举个例子张三的老师就是李四,没有teacherid就是这个 ...
- SQL中的join连接
inner join on,full outer join,left join on,right jion on 1.inner join on 内部连接 两表都满足的组合 2.full outer ...
- flask sql外键使用_如何在SQL中使用外键?
flask sql外键使用 Basically, Foreign Key represents relationship between tables. 基本上, 外键代表表之间的关系 . Synta ...
最新文章
- 给网站管理员的建议:创建可利用的、可抓取的网站
- R绘制发散型条形图(Diverging Bars)
- JavaScript异步编程:异步的数据收集方法
- 解决“ORA-01036: 非法的变量名/编号“错误
- android sdk 更新用的HOSTS
- Fabric学习笔记-智能合约
- 异步下载圆形进度条显示进度
- Git Bash的一些命令和配置
- python自定义函数func_python自定义函数与面向对象
- 32.Linux/Unix 系统编程手册(上) -- 线程:线程取消
- 我开发的内部ORM(一)数据库组件
- TARA-威胁建模方案2
- 怎么去除视频字幕清理视频字幕或水印的四种方法
- hashmap是单向链表吗_LRU(Least Recent Used) java 实现为这么采用HashMap+双向链表
- 51单片机(四)—— 51单片机仿真芯片的使用
- java 正数减去负数,Java中正数与负数操作、的区别
- 变分自编码器和条件变分自编码器 (VAE CVAE)
- 国考面试的形式主要有结构化、无领导小组和结构化小组
- pythonjson数据解析失败_json解析失败是什么意思
- 医院能耗监测管理系统(医院能源管理系统)解决方案
热门文章
- 如何在交换机上查找计算机,通过交换机在局域网中查找病毒攻击的方法
- 影视剧《少年歌行》开机 优酷出品还原热血江湖
- 链游阴阳师:Defina Finance
- 怎么把Firefox浏览器设为Windows系统默认浏览器?
- 内网ip和外网ip的联系以及连接过程
- 三本学计算机还是学土木,浙江哪些三本大学有土木工程专业呀?
- 深圳饿了么java工程师_【饿了么 研发工程师JAVA】-Utips校招-你的名企情报站
- 命运冠位指定服务器连接中断,《命运-冠位指定》1月23日服务器故障相关情况...
- 深度学习网络每一层维度_每个人都可以使用深度学习
- conda安装python3.8虚拟环境报错