LeetCode: 177. Nth Highest Salary

LeetCode: 177. Nth Highest Salary

题目描述

Write a SQL query to get the nth highest salary from the Employee table.

+----+--------+
| Id | Salary | +----+--------+
| 1  | 100    |
| 2  | 200    |
| 3 | 300 | +----+--------+

For example, given the above Employee table, the nth highest salary where n = 2 is 200. If there is no nth highest salary, then the query should return null.

+------------------------+
| getNthHighestSalary(2) | +------------------------+
| 200 | +------------------------+

解题思路

将员工表按照薪水从高到低排序,取第 n 行数据。

AC 代码

CREATE FUNCTION getNthHighestSalary(N INT) RETURNS INT BEGIN DECLARE TMP INT;
  SET TMP=N-1;
  RETURN (
      # Write your MySQL query statement below.
      SELECT * FROM (SELECT DISTINCT Salary FROM Employee ORDER BY Salary DESC) AS So limit TMP,1 );
END
全部评论

相关推荐

给我发了笔试链接,想着等晚上回去做,结果还没做流程就终止了
伟大的小黄鸭在学习:我猜就是笔试几乎没用,就是用来给用人部门拖时间复筛简历的,可能用人部门筛到你简历觉得不合适就提前挂了
投递小鹏汽车等公司10个岗位
点赞 评论 收藏
分享
自学java狠狠赚一...:骗你点star的,港卵公司,记得把star收回去
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务