本篇开始是子查询的学习笔记,首先是一道题目:
where 型子查询,如果是 where 列 =(内层 sql) 则内层 sql 返回的必须是单行单列,单个值。
where 型子查询,如果是 where 列 in(内层 sql) 则内层 sql 返回的必须是单列,可以多行。
在学习 from 子查询之前,需要理解一个概念: 查询结果集在结构上可以当成表看 ,那就可以当成临时表对他进行再次查询:
exists 型子查询是指外层 sql 的结果,拿到内层 sql 去测试,如果内层 sql 成立,则该行取出。学习之前先建一张表:
向里面插入原来 ecshop.ecs_category 中的部分数据:
mysql5.7子分区可以是list的。子分区:也叫作复合分区或者组合分区,即在主分区下再做一层分区,将数据再次分割。
注意:1、RANGE 分区、LIST 分区、HASH 分区都要求分区键必须是 INT 类型,或者通过表达式返回 INT 类型;但 KEY 和 COLUMNS 分区可以使用其他类型的列(BLOB 或 TEXT 列类型除外)作为分区键。
2、无论是哪种分区类型,要么分区表上没有主键/唯一键,要么分区表的主键/唯一键都在分区键上
3、MySQL表的列名、别名、分区名是不区分大小写的。
定义:查询中嵌套查询就是子查询
子查询的本质:
找出工资大于Mark的员工名字和工资
分析:
1.查询出Mark的工资是多少
2.查询出高于1450工资的人
整合成子查询
子查询的特点:
为什么相关子查询的效率极其低下?
结论:
性能排序/优先使用
关联/分组查询>无关子查询>相关子查询
1. 找出工资比'BLAKE'多的员工
2. 列出薪金高于公司平均薪金的所有员工,所在部门
3. 查询出工资最低的员工的姓名,工作,工资
4. 列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金、部门名称
或者
5.查找出职位和'MARTIN' 或者'SMITH'一样的员工的平均工资
6. 列出薪金比“BLAKE”或“WARD”多的所有员工的编号、姓名、部门名称、其领导姓名。
7. 找出各个部门中大于他所在部门平均工资的员工名和工资
8. 查找出收入(工资加上奖金),下级比自己上级还高的员工编号,员工名字,员工收入
9. 得到每个月工资总数最少的那个部门的部门编号,部门名称,部门位置
10. 查找出部门10和部门20中,工资最高第3名到工资第5名的员工的员工名字,部门名字,部门位置
11. 以职位分组,找出平均工资最高的两种职位
12. 查询出各部门总薪资,平均薪资,总人数,显示部门编号,部门名称与部门总薪资(没有员工的部门也需要统计)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)