返回介绍

solution / 1800-1899 / 1875.Group Employees of the Same Salary / README

发布于 2024-06-17 01:03:13 字数 2841 浏览 0 评论 0 收藏 0

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

English Version

题目描述

表: Employees

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

 

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

  • 每个组需要由 至少两个 雇员组成。
  • 同一个组中的所有雇员的 工资相同
  • 工资相同的所有雇员必须被分到同一个组中。
  • 如果某位雇员的工资是独一无二的,那么它 不 被分配到任何一个组中。
  • 组ID的设定基于这个组的工资相对于其他组的 工资的排名,即工资 最低 的组满足 team_id = 1 。注意,排名时 不需要考虑 没有组的雇员的工资。

编写一个解决方案来获取每一个被分配到组中的雇员的 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
WITH
  S AS (
    SELECT salary
    FROM Employees
    GROUP BY salary
    HAVING COUNT(1) > 1
  ),
  T AS (
    SELECT salary, ROW_NUMBER() OVER (ORDER BY salary) AS team_id
    FROM S
  )
SELECT e.*, t.team_id
FROM
  Employees AS e
  JOIN T AS t ON e.salary = t.salary
ORDER BY 4, 1;

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文