sql查询表中第二高的数据

问题:

力扣原题链接:

https://leetcode-cn.com/problems/second-highest-salary/

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

分析:

①先找到最高的元素
②再找出只低于①中找到元素的数据

SQL语句:

分步求

select max(salary) from employee
select max(distinct Salary) from employee where Salary <

考虑可能没有找到并进行整合

select 
    (select max(distinct Salary) from employee where Salary < (select max(salary) from employee)
    ) SecondHighestSalary

第二种方法:

先按照薪水降序排序,找到第二个元素,再使用ifnull来做一个非空判断,同时使用limit来找到元素,此处可以扩展为找到第N高的元素

select ifnull((select distinct e.salary SecondHighestSalary from employee e order by e.salary desc limit 1, 1),null) SecondHighestSalary

使用limit此处有这两种写法,原理是分页的原理,数据库的索引是从0开始的
①直接用是从第1个索引开始,找到1个元素

limit 1,1

②这样子写的话是取1个元素,从索引1开始

limit 1 offset 1
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Jz_Stu

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

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

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

打赏作者

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

抵扣说明:

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

余额充值