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 <排序用列清单> )
*其中[ ]中的内容可以忽略
分类:
数据库
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· Obsidian + DeepSeek:免费 AI 助力你的知识管理,让你的笔记飞起来!
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
2023-03-04 ICSharpCode.SharpZipLib 初级使用
2022-03-04 VS2015没有打包界面,没有Visual Studio Installer