列表

详情


1875. 将工资相同的雇员分组

表: Employees

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| employee_id | int     |
| name        | varchar |
| salary      | int     |
+-------------+---------+
employee_id 是这张表具有唯一值的列.
这个表格的每一行包含雇员 ID, 姓名和工资信息.

 

这家公司想要将 工资相同 的雇员划分到同一个组中。每个组需要满足如下要求:

编写一个解决方案来获取每一个被分配到组中的雇员的 team_id

返回的结果表按照 team_id 升序排列。如果相同,则按照 employee_id 升序排列

返回结果格式如下示例所示。

 

示例 1:

输入:
Employees 表:
+-------------+---------+--------+
| employee_id | name    | salary |
+-------------+---------+--------+
| 2           | Meir    | 3000   |
| 3           | Michael | 3000   |
| 7           | Addilyn | 7400   |
| 8           | Juan    | 6100   |
| 9           | Kannon  | 7400   |
+-------------+---------+--------+
输出:
+-------------+---------+--------+---------+
| employee_id | name    | salary | team_id |
+-------------+---------+--------+---------+
| 2           | Meir    | 3000   | 1       |
| 3           | Michael | 3000   | 1       |
| 7           | Addilyn | 7400   | 2       |
| 9           | Kannon  | 7400   | 2       |
+-------------+---------+--------+---------+
解释:
Meir (employee_id=2) 和 Michael (employee_id=3) 在同一个组中,因为他们的工资都是3000。
Addilyn (employee_id=7) 和 Kannon (employee_id=9) 在同一个组中,因为他们的工资都是7400。
Juan (employee_id=8) 不在任何一个组中,因为他的工资为6100,是独一无二的(即:没有人和他的工资相同)。
组ID按照如下方式分配(基于工资排名,较低的排在前面):
- team_id=1: Meir 和 Michael, 工资是3000
- team_id=2: Addilyn 和 Kannon, 工资是7400
Juan的工资(6100)没有被计算在排名中,因为他不属于任何一个组。

原站题解

去查看

上次编辑到这里,代码来自缓存 点击恢复默认模板
# Write your MySQL query statement below

mysql 解法, 执行用时: 914 ms, 内存消耗: 0 B, 提交时间: 2023-10-15 22:34:28

# Write your MySQL query statement below
SELECT employee_id, name, b.salary, b.team_id
FROM Employees a
INNER JOIN
(SELECT salary, dense_rank() over (ORDER BY salary) AS team_id
FROM Employees
GROUP BY salary
HAVING COUNT(DISTINCT employee_id) > 1) b
ON a.salary = b.salary
ORDER BY b.team_id, employee_id

上一题