SQL實(shí)現(xiàn)LeetCode(176.第二高薪水)
[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.
這道題讓我們找表中某列第二大的數(shù),這道題有很多種解法,先來看一種使用Limit和Offset兩個(gè)關(guān)鍵字的解法,MySQL中Limit后面的數(shù)字限制了我們返回?cái)?shù)據(jù)的個(gè)數(shù),Offset是偏移量,那么如果我們想找第二高薪水,我們首先可以先對薪水進(jìn)行降序排列,然后我們將Offset設(shè)為1,那么就是從第二個(gè)開始,也就是第二高薪水,然后我們將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ù)來做,這個(gè)返回最大值,邏輯是我們?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);
最后來看一種可以擴(kuò)展到找到第N高的薪水的方法,只要將下面語句中的1改為N-1即可,第二高的薪水帶入N-1就是1,下面語句的邏輯是,假如我們要找第二高的薪水,那么我們允許其中一個(gè)最大值存在,然后在其余的數(shù)字中找出最大的,即為整個(gè)的第二大的值;
解法四:
SELECT MAX(Salary) FROM Employee E1 WHERE 1 = (SELECT COUNT(DISTINCT(E2.Salary)) FROM Employee E2 WHERE E2.Salary > E1.Salary);
參考資料:
https://leetcode.com/discuss/47041/very-very-simple-solution
https://leetcode.com/discuss/42849/general-solution-not-using-max
https://leetcode.com/discuss/21751/simple-query-which-handles-the-null-situation
到此這篇關(guān)于SQL實(shí)現(xiàn)LeetCode(176.第二高薪水)的文章就介紹到這了,更多相關(guān)SQL實(shí)現(xiàn)第二高薪水內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SQL實(shí)現(xiàn)LeetCode(184.系里最高薪水)
- SQL實(shí)現(xiàn)LeetCode(183.從未下單訂購的顧客)
- SQL實(shí)現(xiàn)LeetCode(182.重復(fù)的郵箱)
- SQL實(shí)現(xiàn)LeetCode(181.員工掙得比經(jīng)理多)
- SQL實(shí)現(xiàn)LeetCode(180.連續(xù)的數(shù)字)
- SQL實(shí)現(xiàn)LeetCode(178.分?jǐn)?shù)排行)
- SQL實(shí)現(xiàn)LeetCode(177.第N高薪水)
- SQL實(shí)現(xiàn)LeetCode(185.系里前三高薪水)
相關(guān)文章
mysql把主鍵定義為自動(dòng)增長標(biāo)識(shí)符類型
這篇文章主要介紹了mysql中如何把主鍵定義為自動(dòng)增長標(biāo)識(shí)符類型,下面有個(gè)不錯(cuò)的示例,大家可以參考下2014-07-07
mysql數(shù)據(jù)被誤刪的恢復(fù)方案以及預(yù)防措施
這篇文章主要介紹了幾種常見的MySQL數(shù)據(jù)恢復(fù)方法,包括使用備份、二進(jìn)制日志、InnoDB表空間恢復(fù)以及第三方工具,每種方法都有其優(yōu)缺點(diǎn),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-02-02
Windows下mysql community server 8.0.16安裝配置方法圖文教程
這篇文章主要為大家詳細(xì)介紹了Windows下mysql community server 8.0.16安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06
VMware中Linux共享mysql數(shù)據(jù)庫的方法
VMware中Linux共享mysql數(shù)據(jù)庫的方法,需要的朋友可以參考下。2010-11-11
PostgreSQL 正則表達(dá)式 常用函數(shù)的總結(jié)
這篇文章主要介紹了PostgreSQL 正則表達(dá)式 常用函數(shù)的總結(jié)的相關(guān)資料,對那些需要進(jìn)行復(fù)雜數(shù)據(jù)處理的程序來說,正則表達(dá)式無疑是一個(gè)非常有用的工具,這里就介紹下如何使用,需要的朋友可以參考下2017-08-08
MySQL專用服務(wù)器自動(dòng)配置參數(shù)的實(shí)現(xiàn)
本文主要介紹了MySQL專用服務(wù)器自動(dòng)配置參數(shù)的實(shí)現(xiàn),MySQL8.0推出了專用數(shù)據(jù)庫服務(wù)器自動(dòng)配置參數(shù),通過打開innodb_dedicated_server,下面就來詳細(xì)的介紹一下,感興趣的可以了解一下2024-09-09
mysql 8.0.16 Win10 zip版本安裝配置圖文教程
這篇文章主要為大家詳細(xì)介紹了mysql 8.0 Win10 zip版本安裝配置圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06
mysql一對多關(guān)聯(lián)查詢分頁錯(cuò)誤問題的解決方法
這篇文章主要介紹了mysql一對多關(guān)聯(lián)查詢分頁錯(cuò)誤問題的解決方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09

