中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL中怎么利用LeetCode求第二高薪水

發布時間:2021-08-03 18:00:55 來源:億速云 閱讀:145 作者:Leah 欄目:開發技術

這篇文章將為大家詳細講解有關SQL中怎么利用LeetCode求第二高薪水,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

[LeetCode] 176.Second Highest Salary 第二高薪水

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.

這道題讓我們找表中某列第二大的數,這道題有很多種解法,先來看一種使用Limit和Offset兩個關鍵字的解法,MySQL中Limit后面的數字限制了我們返回數據的個數,Offset是偏移量,那么如果我們想找第二高薪水,我們首先可以先對薪水進行降序排列,然后我們將Offset設為1,那么就是從第二個開始,也就是第二高薪水,然后我們將Limit設為1,就是只取出第二高薪水,如果將Limit設為2,那么就將第二高和第三高薪水都取出來:

解法一:

SELECT Salary FROM Employee GROUP BY Salary
UNION ALL (SELECT NULL AS Salary)
ORDER BY Salary DESC LIMIT 1 OFFSET 1;

我們也可以使用Max函數來做,這個返回最大值,邏輯是我們取出的不包含最大值的數字中的最大值,即為第二大值:

解法二:

SELECT MAX(Salary) FROM Employee 
WHERE Salary NOT IN
(SELECT MAX(Salary) FROM Employee);

下面這種方法和上面基本一樣,就是用小于號<代替了Not in關鍵字,效果相同:

解法三:

SELECT MAX(Salary) FROM Employee
Where Salary <
(SELECT MAX(Salary) FROM Employee);

最后來看一種可以擴展到找到第N高的薪水的方法,只要將下面語句中的1改為N-1即可,第二高的薪水帶入N-1就是1,下面語句的邏輯是,假如我們要找第二高的薪水,那么我們允許其中一個最大值存在,然后在其余的數字中找出最大的,即為整個的第二大的值;

解法四:

SELECT MAX(Salary) FROM Employee E1
WHERE 1 =
(SELECT COUNT(DISTINCT(E2.Salary)) FROM Employee E2
WHERE E2.Salary > E1.Salary);

關于SQL中怎么利用LeetCode求第二高薪水就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

读书| 望谟县| 桦甸市| 万山特区| 五寨县| 辉南县| 天长市| 香港| 大田县| 开化县| 兖州市| 晋中市| 乌什县| 菏泽市| 裕民县| 恩施市| 南投市| 宝坻区| 花莲县| 建阳市| 南漳县| 大新县| 肥东县| 宁乡县| 昔阳县| 林周县| 绥江县| 溆浦县| 大田县| 鄂伦春自治旗| 陈巴尔虎旗| 滕州市| 高青县| 昌吉市| 黎平县| 肥东县| 石景山区| 资中县| 龙泉市| 罗甸县| 常熟市|