我是一名立志把细节说清楚的博主,欢迎【关注】🎉 ~
原创不易, 如果有帮助 ,记得【点赞】【收藏】 哦~ ❥(^_-)~
如有错误、疑惑,欢迎【评论】指正探讨,我会尽可能第一时间回复的,谢谢支持
原题
表: Employee
+-------------+---------+
| Column Name | Type |
+-------------+---------+
| id | int |
| name | varchar |
| department | varchar |
| managerId | int |
+-------------+---------+
id 是此表的主键(具有唯一值的列)。
该表的每一行表示雇员的名字、他们的部门和他们的经理的id。
如果managerId为空,则该员工没有经理。
没有员工会成为自己的管理者。
编写一个解决方案,找出至少有五个直接下属的经理。
以 任意顺序 返回结果表。
查询结果格式如下所示。
示例 1:
输入:
Employee
表:
+-----+-------+------------+-----------+
| id | name | department | managerId |
+-----+-------+------------+-----------+
| 101 | John | A | Null |
| 102 | Dan | A | 101 |
| 103 | James | A | 101 |
| 104 | Amy | A | 101 |
| 105 | Anne | A | 101 |
| 106 | Ron | B | 101 |
+-----+-------+------------+-----------+
输出:
+------+
| name |
+------+
| John |
+------+
题解
SELECT e.name
FROM employee e
LEFT JOIN
(SELECT e1.managerId, count(e1.managerId) AS count
FROM employee e1 CROSS JOIN employee e2
ON e1.managerId = e2.id
GROUP BY E1.managerId) mg
ON e.id = mg.managerId
WHERE mg.count>=5
解题笔记
LEFT JOIN
关键字,左连接,又称左外连接,以LEFT JOIN
关键字作为标准,左边的表称为左表,右边的表称为右表。ON
关键字修饰连接条件,左表数据全部展示,右表数据根据连接条件展示对应数据,如右表中无对应数据,则使用NULL
填充右表中无数据的字段。CROSS JOIN
关键字,交叉连接,又称笛卡尔积。GROUP BY
关键字,对结果进行分组。- 关键字详细说明请看文章:【MySQL】数据分组(关键字:GROUP BY)过滤分组(关键字:HAVING)
我是一名立志把细节说清楚的博主,欢迎【关注】🎉 ~
原创不易, 如果有帮助 ,记得【点赞】【收藏】 哦~ ❥(^_-)~
如有错误、疑惑 ,欢迎【评论】指正探讨,我会尽可能第一时间回复的,谢谢支持