• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    SQL实现LeetCode(177.第N高薪水)

    [LeetCode] 177.Nth Highest Salary 第N高薪水

    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.

    这道题是之前那道Second Highest Salary的拓展,根据之前那道题的做法,我们可以很容易的将其推展为N,根据对Second Highest Salary中解法一的分析,我们只需要将OFFSET后面的1改为N-1就行了,但是这样MySQL会报错,估计不支持运算,那么我们可以在前面加一个SET N = N - 1,将N先变成N-1再做也是一样的:

    解法一:

    CREATE FUNCTION getNthHighestSalary(N INT) RETURNS INT
    BEGIN
      SET N = N - 1;
      RETURN (
          SELECT DISTINCT Salary FROM Employee GROUP BY Salary
          ORDER BY Salary DESC LIMIT 1 OFFSET N
      );
    END

    根据对Second Highest Salary中解法四的分析,我们只需要将其1改为N-1即可,这里却支持N-1的计算,参见代码如下:

    解法二:

    CREATE FUNCTION getNthHighestSalary(N INT) RETURNS INT
    BEGIN
      RETURN (
          SELECT MAX(Salary) FROM Employee E1
          WHERE N - 1 =
          (SELECT COUNT(DISTINCT(E2.Salary)) FROM Employee E2
          WHERE E2.Salary > E1.Salary)
      );
    END

    当然我们也可以通过将最后的>改为>=,这样我们就可以将N-1换成N了:

    解法三:

    CREATE FUNCTION getNthHighestSalary(N INT) RETURNS INT
    BEGIN
      RETURN (
          SELECT MAX(Salary) FROM Employee E1
          WHERE N =
          (SELECT COUNT(DISTINCT(E2.Salary)) FROM Employee E2
          WHERE E2.Salary >= E1.Salary)
      );
    END

    类似题目:

    Second Highest Salary

    参考资料:

    https://leetcode.com/discuss/88875/simple-answer-with-limit-and-offset

    https://leetcode.com/discuss/63183/fastest-solution-without-using-order-declaring-variables

    到此这篇关于SQL实现LeetCode(177.第N高薪水)的文章就介绍到这了,更多相关SQL实现第N高薪水内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • SQL实现LeetCode(184.系里最高薪水)
    • SQL实现LeetCode(183.从未下单订购的顾客)
    • SQL实现LeetCode(182.重复的邮箱)
    • SQL实现LeetCode(181.员工挣得比经理多)
    • SQL实现LeetCode(180.连续的数字)
    • SQL实现LeetCode(178.分数排行)
    • SQL实现LeetCode(176.第二高薪水)
    • SQL实现LeetCode(185.系里前三高薪水)
    上一篇:Mysql 日期格式化及复杂日期区间查询
    下一篇:SQL实现LeetCode(178.分数排行)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    SQL实现LeetCode(177.第N高薪水) SQL,实现,LeetCode,177.,第,高薪水,