使用oracle實現獲取第N高薪水


編寫一個 SQL 查詢,獲取 Employee 表中第 n 高的薪水(Salary)。

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

例如上述 Employee 表,n = 2 時,應返回第二高的薪水 200。如果不存在第 n 高的薪水,那么查詢應返回 null

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

 

網上有很多關於mysql的編寫方法,oracle的幾乎找不到,我如果有比我編寫方法好的歡迎評論

CREATE FUNCTION getNthHighestSalary(N IN NUMBER) RETURN NUMBER IS

result NUMBER;

BEGIN

/* Write your PL/SQL query statement below */

select salary into result

from (select salary,rownum as rn

from

(select DISTINCT salary from employee order by salary desc)

)

where rn = N;

RETURN result;

END;


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM