连表查询:总是在连接的时候创建一张大表,里面存放的是两张表的笛卡尔积。再根据条件进行筛选。
数据准备
笛卡尔集加条件约束,
department.id=dep_id 因为 department的id和employee中的id同名,所以在前面加了表名。
表与表之间的连接方式
select *from 表1,表2 where 条件
内连接:select *from 表1 inner join 表2 on 条件
外连接:左外连接,右外连接,全连接
左外连接:left join…on
select *from 表1 left join 表2 on 条件
全外连接,mysql中没有可以用union实现
找到技术部所有人的姓名
找到人力资源部的年龄大于40岁人的姓名
求每个部门有多少人
这个部门没有显示运营部门的人,是不对的
count(d.id)是不对的,因为运营部没人
count(e.id)是对的,一般情况都是count主键
求每一个部门有多少人并按照人数从高到低排序
连表就是把两张表连接在一起之后,就变成一张达标,从from开始一直到on条件结束就看作一张表,之后where条件,group by,分组,order by limit 都可以正常使用了
子查询
带in关键字的子查询
查询平均年龄在25岁以上的部门名
查看技术部门员工姓名
先查询技术部的部门id
再根据这个部门id找到对应的员工名
in可以换成=
查看不足1人的部门名(子查询得到的是有人的部门id)
带比较运算符的查询
查询大于所有人平均年龄的员工名与年龄
;
查询大于部门内平均年龄的员工名、年龄
exists
表示存在,使用exists关键字时,内层查询语句不返回查询的记录。而是返回一个真假值。True或False。当返回True时,外层查询语句将进行查询,当返回False时,外层查询语句不进行查询。