您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關(guān)SQL中怎么利用LeetCode求第二高薪水,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
Write a SQL query to get the second highest salary from the Employee table.
+----+--------+
| Id | Salary |
+----+--------+
| 1 | 100 |
| 2 | 200 |
| 3 | 300 |
+----+--------+
For example, given the above Employee table, the second highest salary is 200. If there is no second highest salary, then the query should return null.
這道題讓我們找表中某列第二大的數(shù),這道題有很多種解法,先來看一種使用Limit和Offset兩個關(guān)鍵字的解法,MySQL中Limit后面的數(shù)字限制了我們返回數(shù)據(jù)的個數(shù),Offset是偏移量,那么如果我們想找第二高薪水,我們首先可以先對薪水進行降序排列,然后我們將Offset設(shè)為1,那么就是從第二個開始,也就是第二高薪水,然后我們將Limit設(shè)為1,就是只取出第二高薪水,如果將Limit設(shè)為2,那么就將第二高和第三高薪水都取出來:
解法一:
SELECT Salary FROM Employee GROUP BY Salary UNION ALL (SELECT NULL AS Salary) ORDER BY Salary DESC LIMIT 1 OFFSET 1;
我們也可以使用Max函數(shù)來做,這個返回最大值,邏輯是我們?nèi)〕龅牟话畲笾档臄?shù)字中的最大值,即為第二大值:
解法二:
SELECT MAX(Salary) FROM Employee WHERE Salary NOT IN (SELECT MAX(Salary) FROM Employee);
下面這種方法和上面基本一樣,就是用小于號<代替了Not in關(guān)鍵字,效果相同:
解法三:
SELECT MAX(Salary) FROM Employee Where Salary < (SELECT MAX(Salary) FROM Employee);
最后來看一種可以擴展到找到第N高的薪水的方法,只要將下面語句中的1改為N-1即可,第二高的薪水帶入N-1就是1,下面語句的邏輯是,假如我們要找第二高的薪水,那么我們允許其中一個最大值存在,然后在其余的數(shù)字中找出最大的,即為整個的第二大的值;
解法四:
SELECT MAX(Salary) FROM Employee E1 WHERE 1 = (SELECT COUNT(DISTINCT(E2.Salary)) FROM Employee E2 WHERE E2.Salary > E1.Salary);
關(guān)于SQL中怎么利用LeetCode求第二高薪水就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。