LeetCode 刷题 - 数据库 176. 第二高的薪水

151 阅读1分钟

SQL架构

Create table If Not Exists Employee (Id int, Salary int)
Truncate table Employee
insert into Employee (Id, Salary) values ('1', '100')
insert into Employee (Id, Salary) values ('2', '200')
insert into Employee (Id, Salary) values ('3', '300')

编写一个 SQL 查询,获取 Employee 表中第二高的薪水(Salary) 。

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

例如上述 Employee 表,SQL查询应该返回 200 作为第二高的薪水。如果不存在第二高的薪水,那么查询应返回 null。

+---------------------+
| SecondHighestSalary |
+---------------------+
| 200                 |
+---------------------+

来源:力扣(LeetCode)
链接:leetcode-cn.com/problems/se…
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处


答案:

方法一:去重

执行用时 :119 ms, 在所有 MySQL 提交中击败了13.75%的用户
内存消耗 :0B, 在所有 MySQL 提交中击败了100.00%的用户

SELECT
	IFNULL(
		(SELECT MAX( DISTINCT salary ) 
		FROM employee 
		WHERE salary NOT IN ( 
    		SELECT MAX( salary ) 
    		FROM employee ) 
		ORDER BY salary DESC ),
	NULL ) AS SecondHighestSalary


方法二:分页

执行用时 :166 ms, 在所有 MySQL 提交中击败了6.16%的用户
内存消耗 :0B, 在所有 MySQL 提交中击败了100.00%的用户

SELECT
    IFNULL(
      (SELECT DISTINCT Salary
       FROM Employee
       ORDER BY Salary DESC
        LIMIT 1 OFFSET 1),
    NULL) AS SecondHighestSalary