JobHoppoer-SQL-176. Second Highest Salary

- 要求返回列表,所以最外层 又包了一层 SELECT

- 得到第 n 行,关键词 LIMIT 1 OFFSET (n-1),或者简写成 LIMIT (n-1), 1; 注意: 顺序相反

- SELECT DISTINCT 避免 duplicates.

- ORDER BY col_name DESC 降序排列。

# Write your MySQL query statement below

-- The below one does not give an empty list when there is 1 row. 
-- SELECT salary SecondHighestSalary FROM Employee ORDER BY salary DESC LIMIT 1,1; 
-- DINSTINCT is needed to deal with duplicates.

SELECT 
    (SELECT DISTINCT 
        salary 
     FROM Employee 
     ORDER BY salary 
     DESC LIMIT 1 OFFSET 1) AS SecondHighestSalary
;

之前的写法很 hacky,不generic

# Write your MySQL query statement below
SELECT max(Salary) as SecondHighestSalary
FROM Employee
WHERE Salary < (SELECT max(Salary) FROM Employee)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值