MySQL数据库基础学习(三十)
2023-02-19 12:23:47 时间
5.5 自连接
5.5.1 自连接查询
自连接查询,顾名思义,就是自己连接自己,也就是把一张表连接查询多次。我们先来学习一下自连接的查询语法:
SELECT 字段列表 FROM 表A 别名A JOIN 表A 别名B ON 条件 ... ;
而对于自连接查询,可以是内连接查询,也可以是外连接查询。
案例:
A. 查询员工 及其 所属领导的名字
表结构: emp
select a.name , b.name from emp a , emp b where a.managerid = b.id;
B. 查询所有员工 emp 及其领导的名字 emp , 如果员工没有领导, 也需要查询出来表结构: emp a , emp b
select a.name '员工', b.name '领导' from emp a left join emp b on a.managerid =
b.id;
注意事项:
在自连接查询中,必须要为表起别名,要不然我们不清楚所指定的条件、返回的字段,到底是哪一张表的字段。
5.5.2 联合查询
对于union查询,就是把多次查询的结果合并起来,形成一个新的查询结果集。
SELECT 字段列表 FROM 表A ...
UNION [ ALL ]
SELECT 字段列表 FROM 表B ....;
对于联合查询的多张表的列数必须保持一致,字段类型也需要保持一致。
union all 会将全部的数据直接合并在一起,union 会对合并之后的数据重。
案例:
A. 将薪资低于 5000 的员工 , 和 年龄大于 50 岁的员工全部查询出来.
当前对于这个需求,我们可以直接使用多条件查询,使用逻辑运算符 or 连接即可。那这里呢,我们也可以通过union/union all来联合查询.
select * from emp where salary < 5000
union all
select * from emp where age > 50;
union all查询出来的结果,仅仅进行简单的合并,并未去重。
select * from emp where salary < 5000
union
select * from emp where age > 50;
union 联合查询,会对查询出来的结果进行去重处理。
注意:
如果多条查询语句查询出来的结果,字段数量不一致,在进行union/union all联合查询时,将会报错。如:
相关文章
- 入坑两个月自研非外包创业公司,居然让我搞懂了Volatile
- Node.js C++ 层的任务管理
- 2023,让RFID固定资产管理系统助力企业降本增效
- 基于AI深度学习的安全帽检测算法,如何应用在实际场景中?
- 简洁的 Go 多版本管理机制
- 混合多云管理, 实现一体化运营与治理
- BT - Unet:生物医学图像分割的自监督学习框架
- 前端图形学实战: 从零实现编辑器的图层管理面板和实时缩略图(vue3 + vite版)
- 为什么公司规定所有接口都必须加上分布式锁,你知道吗?
- 使用Python进行交易策略和投资组合分析
- 推荐19个Github热门的TypeScript学习宝库及项目
- 【PASA集群管理神器】Glang竟然可以做出那么惊艳的系统
- CSO面对面丨顺丰科技谭林谈物流企业安全建设:实战是检验防护能力的唯一标准
- 万字整理内存管理之Cache
- 手把手教你用 Python 脚本调用 DeepL API Pro 进电子书的行进行中英文自动翻译
- 万字长文 | Linux C/C++ 后台服务器开发学习路线
- Linux内存管理:memblock
- Buddy 内存管理机制(上)
- Buddy 内存管理机制(下)
- 学习新编程语言的七个简单有效的技巧