编写一个 SQL 查询,获取 Employee
表中第 n 高的薪水(Salary)。
例如上述 Employee
表,n = 2 时,应返回第二高的薪水 200
。如果不存在第 n 高的薪水,那么查询应返回 null
。
解法一:实际解答时先删掉函数再创建,避免报错的麻烦。
#DROP FUNCTION IF EXISTS getNthHighestSalary;
CREATE FUNCTION getNthHighestSalary(N INT) RETURNS INT
BEGIN
SET N = N-1;
RETURN (
# Write your MySQL query statement below.
select if(count(salary)>=1,max(salary),null) as a from (
select salary from employee group by salary ORDER BY salary desc limit N,2) as t
);
END