SQL中的开窗函数

https://blog.csdn.net/weixin_51309915/article/details/121880904

一、什么是开窗函数
开窗函数/分析函数:over()

开窗函数也叫分析函数,有两类:

一类是聚合开窗函数,一类是排序开窗函数。

开窗函数的调用格式为:

1
函数名(列名) OVER(partition by 列名 order by列名) 。 

聚合函数sum、avg、count、max、min都是针对自身记录以及自身记录以上的所有数据进行计算的

开窗函数和聚合函数的区别如下:

(1)SQL 标准允许将所有聚合函数用作开窗函数,用OVER 关键字区分开窗函数和聚合函数。

(2)聚合函数每组只返回一个值,开窗函数每组可返回多个值。

二、下面介绍三种用于进行排序的专用窗口函数
1、RANK()

在计算排序时,若存在相同位次,会跳过之后的位次。
例如,有3条排在第1位时,排序为:1,1,1,4······

2、DENSE_RANK()

这就是题目中所用到的函数,在计算排序时,若存在相同位次,不会跳过之后的位次。
例如,有3条排在第1位时,排序为:1,1,1,2······

3、ROW_NUMBER()

这个函数赋予唯一的连续位次。
例如,有3条排在第1位时,排序为:1,2,3,4······

举例:

此时用到开窗函数

1
2
3
4
5
select emp_no , salary ,
DENSE_RANK() over (order by salary desc) as t_rank
from salaries where
to_date = '9999-01-01'
order by t_rank asc ,emp_no asc;

 

窗口函数用法: <窗口函数> OVER ( [PARTITION BY <列清单> ]
ORDER BY <排序用列清单> )
*其中[ ]中的内容可以忽略

posted @   yinghualeihenmei  阅读(206)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· Obsidian + DeepSeek:免费 AI 助力你的知识管理,让你的笔记飞起来!
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
历史上的今天:
2023-03-04 ICSharpCode.SharpZipLib 初级使用
2022-03-04 VS2015没有打包界面,没有Visual Studio Installer
点击右上角即可分享
微信分享提示