176.求第二高薪水

List item

题目

Employee表:
±------------±-----+
| Column Name | Type |
±------------±-----+
| id | int |
| salary | int |
±------------±-----+
id 是这个表的主键。
表的每一行包含员工的工资信息。

编写一个sql查询,获取并返回Employee表中第二高的薪水,如果不存在第二高的薪水,查询应该返回null.

查询结果格式如下:
示例1:
Employee 表:
±—±-------+
| id | salary |
±—±-------+
| 1 | 100 |
| 2 | 200 |
| 3 | 300 |
±—±-------+
输出:
±--------------------+
| SecondHighestSalary |
±--------------------+
| 200 |
±--------------------+

示例2:
输入:
Employee 表:
±—±-------+
| id | salary |
±—±-------+
| 1 | 100 |
±—±-------+
输出:
±--------------------+
| SecondHighestSalary |
±--------------------+
| null |
±--------------------+

解答思路

思路1:
1.先求出员工的最高工资;
2.找工资低于最高工资的工资,并在这部分工资里面找最大的工资.

思路2:
1.将员工工资按照降序排列,并且排名;
2.以1的表为临时表,查找排名=2的工资,如果有的话打印出工资,没有的话返回空.

思路3:
1.将员工工资按照降序排列,并且排名;
2.以1的表为临时表,查找排名=2的工资 ;
3.外面再写一次select语句,如果有值的话返回值本身,没有值返回null.

考察点:
1.max(列名)
2.where条件的使用
3.子查询当作临时表
4.if(a,b,默认值),如果满足a,则输出b,否则输出默认值.
5.起别名用as

参考答案
思路1:
select max(salary) as SecondHighestSalary
from Employee
where salary < (select max(salary) as max from Employee);

思路2:
WITH temp AS (
SELECT salary,dense_rank() OVER (ORDER BY salary DESC ) AS rank
FROM Employee
)
SELECT max(if(rank=2,salary,NULL)) AS SecondHighestSalary
FROM temp;

思路3:
SELECT (
WITH temp AS (
SELECT salary,dense_rank() OVER (ORDER BY salary DESC ) AS rank
FROM Employee
)
SELECT salary
FROM temp
WHERE rank = 2
) AS SecondHighestSalary;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lucky bigdata

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值