百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Mysql中的关联查询(内连接,外连接,自连接)

ccwgpt 2024-12-04 11:56 22 浏览 0 评论

  • 内连接查询
  • 左外连接查询
  • 右外连接查询
  • 全外连接查询
  • 自连接查询

内连接查询

是指所有查询出的结果都是能够在连接的表中有对应记录的。

以t_employee(员工表)和t_dept(部门表)为例:

t_employee表:

t_dept表:

可以发现,其中人力资源部里没有员工(这里只是举例,可能与实际不符,但主要在于逻辑关系),而赵七没有对应的部门,现在想要查询出员工姓名以及其对应的部门名称:

此时,就要使用内连接查询,关键字(inner join)e.

在这里说一下关联查询sql编写的思路:

1,先确定所连接的表
2,再确定所要查询的字段
3,确定连接条件以及连接方式

查询:

select e.id,e.empName,d.deptName from t_employee e inner join t_dept on e.dept=d.id

查询结果如下:

其中,没有部门的人员和没有员工的部门都没有被查询出来,这就是内连接的特点,只查询在连接的表中能够有对应的记录,其中e.dept = d.id是连接条件,如下集合图形所示:


左外连接查询

是指以左边的表的数据为基准,去匹配右边的表的数据,如果匹配到就显示,匹配不到就显示为null。例如:

查询所有员工姓名以及他所在的部门名称:在内连接中赵七没有被查出来,因为他没有对应的部门,现在想要把赵七也查出来,就要使用左外连接:

select e.id,e.empName,d.deptName from employee e left join dept d on e.dept = d.id

在这里,t_employee就是左表,也就是基准表,用基准表的数据去匹配右表的数据,所以左表的记录是全部会查询出来的,如果右表没有记录对应的话就显示null

查询结果:

关键字是left outer join,等效于left join,在关联查询中,做外连接查询就是左连接查询,两者是一个概念,集合图形如下:

左外连接扩展:

进行如下查询:查询所有员工姓名及部门名称,每个员工必须要有部门

select 
	e.id,e.empName,d.deptName 
from 
	employee e 
left join 
	dept d 
on 
	e.dept = d.id 
where 
	d.i is not null;

查询结果:

集合图形如下所示:


右外连接

右外连接与左外连接相似,只需将left join 改为 right join即可,不做过多的赘述。

集合关系图如下:

扩展集合图形:


全外连接

顾名思义,把两张表的字段都查出来,没有对应的值就显示null,但是注意:mysql是没有全外连接的(mysql中没有full outer join关键字),想要达到全外连接的效果,可以使用union关键字连接左外连接和右外连接。例如:

select 
	e.id,e.empName,d.deptName 
from 
	employee e 
left join 
	dept d 
on 
	e.dept = d.id 
union
select 
	e.id,e.empName,d.deptName 
from 
	employee e 
right join 
	dept d 
on 
	e.dept = d.id ;

查询结果:

集合图形如下所示:

如果在oracle中,直接就使用full outer join关键字连接两表就行了


自连接查询

自连接查询就是当前表与自身的连接查询,关键点在于虚拟化出一张表给一个别名

例如:查询员工以及他的上司的名称,由于上司也是员工,所以这里虚拟化出一张上司表

select 
	a.id id,a.empName empName,b.empName bossName 
 from 
 	employee a 
 left join 
 	employee b 
 on 
 	b.bossId = a.id;

查询结果:

自连接查询一般用作表中的某个字段的值是引用另一个字段的值,比如权限表中,父权限也属于权限





由于工作关系,后期文章将以一天一小篇七天一大片模式持续更新




相关推荐

公司组织架构及部门职责#管理制度 #薪酬绩效 #组织架构

...

终于把“公司组织架构与管理部岗位配置”整理好了,拿来即用!

...

老板看完这份“公司组织架构详解”就解放了!

...

丨公司丨公司大架构整理汇总

注:本文转自团队成员原创作品,特此鸣谢(公号:法海图鉴)今日话题公司大架构整理背景介绍经过前几期话题对各种企业类型的介绍,想必大家已经有了初步认识。之后我将带着大家开启对公司的深入了解。本期...

图解物理--八年级物理下册最全知识框架导图

第七章力1力2弹力3重力第八章运动和力1牛顿第一定律2二力平衡3摩擦力第九章压强1压强2液体压强3大气压强4流体压强与流速的关系第十章浮力1浮力2阿基米德原理3物体的浮沉条件及应用第十一章功...

八年级上册生物,思维导图,期末高分必备资料,家长收藏

这是八年级上册生物的思维导图,孩子在背诵知识点的时候,可以看一下知识点在导图中的位置,形成对知识点整体的把握,有助于学生拿高分,特别是图片中带红色星星的部分,更是要注意背诵,是重点内容。家长可以把图片...

2019政府工作报告精华,这张思维导图里全都有

每经记者:李可愚每经编辑:陈星每日经济新闻

图解薪酬体系结构设计

...

司考复习独家总结!一张图总结行政法知识结构体系

作为三大实体法之一,行政法的分值在60分左右,行政法在司法考试中一直比较平稳常规,没有偏题怪题,还是比较容易得分的。小编要提醒大家,在3月之前要把三大实体法学习一遍。下图是厚大在线360导学师小周总结...

一图读懂香港国安新架构:各职位人选公布 有官员曾强硬喊话乱港分子

实用干货!高中物理框架图,让零碎知识“串联”起来

高中物理学习一定要抓好逻辑结构大框架!了解整个知识框架体系后,更易抓住骨干知识,干掉重难知识点~今天给大家分享高中物理的框架图同学们赶紧收藏起来吧!力学知识结构图光学知识结构图热学、原子物理知识结构图...

254m超高层办公楼型钢砼框架-核心筒结构图

高度类别:超高层建筑钢筋混凝土结构:框架,框架核心筒钢结构:钢框架建筑功能:办公包含:办公楼57层(-3层)254.150m钻孔灌注桩桩+筏板型钢混凝土框架-钢筋混凝土核心筒西裙房2层(-...

砖混结构与框架结构,究竟有何区别?千万别被坑!

现在买房装修的人最怕啥?不是价格高,而是房子不安全!两种主流建筑结构,砖混靠墙,框架靠柱子,选错了隔墙都可能要命。简单说,砖混便宜但别碰高层,框架贵点但能保命。砖混那些承重墙根本不能拆,想砸墙改个开放...

大师一百——高中化学必考:《元素周期律》考点框架图

今天大师给大家带来的是高中化学的《元素周期律》考点框架图,高中的同学必须牢记于心,这种重要的考点,考试是一定会考的!化学大师...

需求分析框架图

需求分析框架图

取消回复欢迎 发表评论: