网站首页 > 技术文章 正文
- 内连接查询
- 左外连接查询
- 右外连接查询
- 全外连接查询
- 自连接查询
内连接查询
是指所有查询出的结果都是能够在连接的表中有对应记录的。
以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;
查询结果:
自连接查询一般用作表中的某个字段的值是引用另一个字段的值,比如权限表中,父权限也属于权限。
由于工作关系,后期文章将以一天一小篇七天一大片模式持续更新
猜你喜欢
- 2024-10-19 详解oracle分页存储过程---附实例分享
- 2024-10-19 详解Oracle 数据库enq:TX-index contention等待事件及解决方案
- 2024-10-19 分享一个在表关联时降低业务逻辑复杂度的查询sql
- 2024-10-19 「Oracle」为大家带来connect by的用法,Oracle的递归
- 2024-10-19 基于dba_lobs查找Oracle中lobsegment、lobindex与表之间关系
- 2024-10-19 Oracle项目管理系统之沟通协作 oracle 合作伙伴
- 2024-10-19 oracle sql优化 oracle sql优化的几种方法
- 2024-10-19 关于Oracle中重复数据只取一条记录
- 2024-10-19 ORACLE PL/SQL中异常处理全面分析
- 2024-10-19 大公司oracle笔试题及答案(2) oracle公司待遇如何
你 发表评论:
欢迎- 05-10如何优化数据库和前端之间的交互?
- 05-10前端代码优化小秘籍(前端优化24条建议)
- 05-10VS Code当中的15个神仙插件,值得收藏
- 05-10如何自己开发一个Google浏览器插件?
- 05-10前端流行框架Vue3教程:14. 组件传递Props效验
- 05-10吃了一年的SU,最好用的插件都在这了
- 05-10前端必看!这款神器让网站界面告别千篇一律
- 05-10程序员请收好:10个非常有用的 Visual Studio Code 插件
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle查询数据库 (45)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)