MySQL中的窗口函数

8 篇文章 0 订阅

参考:【1】https://www.cnblogs.com/DataArt/p/9961676.html 介绍的非常详细

MySQL 8.0后开始有窗口函数的。

窗口函数是作用域于每条语句上的,会返回相同数据量的行数。聚合函数会根据计算结果返回一个值。

窗口函数的一般格式:

function_name()over(write SQL) 

按照功能划分,可以把MySQL支持的窗口函数分为如下几类:

  • 序号函数:row_number() / rank() / dense_rank()

  • 分布函数:percent_rank() / cume_dist()

  • 前后函数:lag() / lead()

  • 头尾函数:first_val() / last_val()

  • 其他函数:nth_value() / nfile()

在题目中的应用:

【1】176. 第二高的薪水  因为leetcode的Mysql不是8.0的,所以我用了一下 SQL Server。

select 
ISNULL(
    (
        select distinct a.Salary 
        from
            (select DENSE_RANK()over(order by Salary desc ) row_no,Salary 
            from Employee ) as a
        where 
            a.row_no=2
    ),NULL) AS "SecondHighestSalary"

【2】 177. 第N高的薪水 用了窗口函数

CREATE FUNCTION getNthHighestSalary(@N INT) RETURNS INT AS
BEGIN
    RETURN (
        /* Write your T-SQL query statement below. */
        select distinct Salary
        from(
            select dense_rank()over(order by Salary desc ) row_no,Salary
            from Employee) t
        where t.row_no=@N 
    );
END

row_number() 从1排到最后,不管里面的排序的关系。 

rank() 不连续的数字排序,管里面的顺序,但是会计算每个重复元素的个数。

dense_rank()  连续的数字排序,会将大小相同的,排成序号相同的。

【3】178. 分数排名

select Score, 
      dense_rank()over(order by Score desc ) as 'Rank'
from Scores 

【4】184. 部门工资最高的员工

select a.Department,a.Employee,a.Salary
from (
    select ee.Name as Employee,de.Name as Department,
    dense_rank() over(partition by ee.DepartmentId order by ee.Salary desc ) as row_no,ee.Salary
    from Employee as ee inner join Department as de  on ee.DepartmentId=de.Id 
) a
where a.row_no=1

【5】185. 部门工资前三高的所有员工 

/* Write your T-SQL query statement below */
select de.NAME Department,a.nAME Employee,a.Salary
from (
    select Name,DepartmentId,Salary,
    dense_rank() over(partition by DepartmentId order by Salary desc ) as row_no
    from Employee
) a join Department de on a.DepartmentId=de.Id
where a.row_no<=3

 

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Foneone

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

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

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

打赏作者

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

抵扣说明:

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

余额充值