本文主要是介绍leetcode 1303 求团队人数(postgresql),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
需求
员工表:Employee
±--------------±--------+
| Column Name | Type |
±--------------±--------+
| employee_id | int |
| team_id | int |
±--------------±--------+
employee_id 字段是这张表的主键,表中的每一行都包含每个员工的 ID 和他们所属的团队。
编写一个 SQL 查询,以求得每个员工所在团队的总人数。
查询结果中的顺序无特定要求。
查询结果格式示例如下:
Employee Table:
±------------±-----------+
| employee_id | team_id |
±------------±-----------+
| 1 | 8 |
| 2 | 8 |
| 3 | 8 |
| 4 | 7 |
| 5 | 9 |
| 6 | 9 |
±------------±-----------+
Result table:
±------------±-----------+
| employee_id | team_size |
±------------±-----------+
| 1 | 3 |
| 2 | 3 |
| 3 | 3 |
| 4 | 1 |
| 5 | 2 |
| 6 | 2 |
±------------±-----------+
ID 为 1、2、3 的员工是 team_id 为 8 的团队的成员,
ID 为 4 的员工是 team_id 为 7 的团队的成员,
ID 为 5、6 的员工是 team_id 为 9 的团队的成员。
输入
输出
with t1 as (
select team_id,count(1) as num
from employee
group by team_id
)
select e.employee_id,num
from employee e,t1
where e.team_id=t1.team_id
;
这篇关于leetcode 1303 求团队人数(postgresql)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!