(三)SQL窗口分析函数 #SQL #CDA学习打卡

目录

[一. 窗口分析函数](#一. 窗口分析函数)

1)前后函数

(a)lag

(b)lead

2)头尾函数

[(a)first value](#(a)first value)

[(b)last value](#(b)last value)

3)排序函数

(a)row_number

(b)rank

(c)dense_rank

(d)三者之间对比

4)分布函数

(a)cume_dist

(b)percent_rank

(c)两者之间对比

5)其它函数

(a)ntile


一. 窗口分析函数

窗口分析函数主要用来做数据统计分析,属于OLAP方式。OLAP联机分析处理和OLTP联机事务处理是两种常见的数据库处理方式,通常分析师更喜爱OLAP(分析),开发者更关注的是OLTP(事务)。

窗口分析函数可以计算一定范围内、一定值域内、或者一段时间内的累积和以及移动平均值等,可以方便的实现复杂的数据统计分析需求。

窗口分析函数包括:

前后函数:lag,lead

头尾函数:first-val,last val

排序函数:rank,dense rank,row number

分布函数:percent_rank,cume_dist

聚合函数:sum,count,min,max,avg

其它函数:ntile

1)前后函数

(a)lag

(b)lead

2)头尾函数

(a)first value

(b)last value

3)排序函数

(a)row_number

(b)rank

(c)dense_rank

(d)三者之间对比

row_number()不区分是否并列:row_number函数为每一行分配唯一的行号,而rank函数和dense_rank函数在处理具有相同排序值的行时有所不同。

**rank()会产生序号相同的记录,产生序号间隔,dense_rank()不产生序号间隔:**rank函数会跳过下一个排名,而dense_rank函数会紧随其后。选择使用哪个函数取决于具体的需求和对重复值的处理方式。

4)分布函数

用于计算当前行在排序结果中的累积分布比例。

(a)cume_dist

(b)percent_rank

(c)两者之间对比

5)其它函数

(a)ntile

Bye!

相关推荐
musenh33 分钟前
css样式学习
css·学习·css3
workflower38 分钟前
FDD(Feature Driven Development)特征驱动开发
大数据·数据库·驱动开发·需求分析·个人开发
Larry_Yanan1 小时前
QML学习笔记(五十)QML与C++交互:QML中单例C++对象
开发语言·c++·笔记·qt·学习·ui·交互
im_AMBER1 小时前
算法笔记 09
c语言·数据结构·c++·笔记·学习·算法·排序算法
韩立学长1 小时前
基于Springboot的旧物公益捐赠管理系统3726v22v(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
Nan_Shu_6142 小时前
学习:JavaScript(5)
开发语言·javascript·学习
苦学编程的谢2 小时前
Redis_4_常见命令(完)+认识数据类型和编码方式
数据库·redis·缓存
小光学长2 小时前
基于Vue的儿童手工创意店管理系统as8celp7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
小光学长2 小时前
基于Vue的地铁综合服务管理系统7949eg04(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
民乐团扒谱机2 小时前
实验室安全教育与管理平台学习记录(八)特种设备安全
学习·安全