sql查询表中第二高的数据

算法题记录 专栏收录该内容
4 篇文章 0 订阅

问题:

力扣原题链接:

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
    点赞
  • 0
    评论
  • 1
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 游动-白 设计师:白松林 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值