当前位置: 首页 > news >正文

LeetCode--570. 至少有5名直接下属的经理

文章目录

  • 1 题目描述
  • 2 测试用例
  • 3 解题思路
    • 3.1 解法 1

1 题目描述

表: Employee

+-------------+---------+  
| Column Name | Type    |  
+-------------+---------+  
| id          | int     |  
| name        | varchar |  
| department  | varchar |  
| managerId   | int     |  
+-------------+---------+  

在 SQL 中, id 是该表的主键列
该表的每一行都表示雇员的名字, 他们的部门和他们的经理的 id
如果 managerId 为空, 则该员工没有经理
没有员工会成为自己的管理者

查询至少有 5 名直接下属的经理
任意顺序 返回结果表

2 测试用例

输入:
Employee 表:

+-----+-------+------------+-----------+  
| id  | name  | department | managerId |  
+-----+-------+------------+-----------+  
| 101 | John  | A          | None      |  
| 102 | Dan   | A          | 101       |  
| 103 | James | A          | 101       |  
| 104 | Amy   | A          | 101       |  
| 105 | Anne  | A          | 101       |  
| 106 | Ron   | B          | 101       |  
+-----+-------+------------+-----------+  

输出:

+------+  
| name |  
+------+  
| John |  
+------+  

3 解题思路

  1. 至少有 5 名直接下属, 能想到用 group by managerId having count(*) >= 5 查找符合要求的经理信息
select managerId from Employee group by managerId having count(*) >= 5  

查询结果

managerId
101
  1. 管理查询获取经理的姓名
select e1.name  
from Employee e1  join (select managerId from Employee group by managerId having count(*) >= 5) e2 on e1.id = e2.managerId;  

查询结果

name
John

3.1 解法 1

从解题思路能得到最终的答案

select e1.name  
from Employee e1  join (select managerId from Employee group by managerId having count(*) >= 5) e2 on e1.id = e2.managerId;  
http://www.lryc.cn/news/220142.html

相关文章:

  • Ubuntu20.04下安装Redis环境
  • 什么是用户体验测试? 为什么很重要?
  • Android 图片翻面动画
  • 如何恢复已删除的PDF文件?4个常用方法分享(含操作步骤)!
  • head first python 第一章-新代码更新pypi
  • mysql之备份和恢复
  • 【音视频 | Ogg】libogg库详细介绍以及使用——附带libogg库解析.opus文件的C源码
  • 如何使用群晖NAS的Audio Station结合内网穿透实现远程访问本地曲库
  • 要在CentOS中安装Docker
  • Android Gldie复用只取之前decode过的缓存resource,Kotlin
  • EasyExcel实现动态表头功能
  • Python | 安装、环境配置及包的安装
  • CentOS 7 安装 JDK17(注意版本号要与自己的版本一致)
  • JavaScript 数组操作
  • idea使用lombok编译问题
  • GoLong的学习之路(番外)如何使用依赖注入工具:wire
  • 【pyspider】爬取ajax请求数据(post),如何处理python2字典的unicode编码字段?
  • torch.cumprod实现累乘计算
  • 设计模式之迭代器模式
  • 使用SSH ,让windows和linux互通
  • 常用设计模式——策略模式
  • 牛客网 CM11.链表分割
  • [iOS开发]iOS中TabBar中间按钮凸起的实现
  • 数字时代,企业的数据共享意味着什么?
  • 壹[1],QT自定义控件创建(QtDesigner)
  • 解决Java对接LDAP AD域登录出现Unprocessed Continuation Reference(s)错误
  • could not read ok from ADB Server
  • 超越基础:Flutter 中 onTap 的 5 条规则让你脱颖而出
  • 综合布线可视化管理系统价值分析
  • 【JavaSE】基础笔记 - 类和对象(上)