网站首页 > 知识剖析 正文
文章来源于数据仓库与Python大数据 ,作者大圣归来
数据库SQL分析函数/窗口函数专题,值得收藏!几乎涵盖所有数据库,例如:Oracle、Hive、MySQL8.0、MaxComputer等。企业面试中,更是钟情分析函数问题,笔试、面试到基本跑不了。
分析函数主要分为四类:
1.聚合分析函数
2.排名分析函数
3.数学分析函数
4.行比较分析函数
一.聚合分析函数
SUM :该函数计算组中表达式的累积和
COUNT :对一组内发生的事情进行累积计数
MIN :在一个组中的数据窗口中查找表达式的最小值
MAX :在一个组中的数据窗口中查找表达式的最大值
AVG :用于计算一个组和数据窗口内表达式的平均值。
二.排名分析函数
ROW_NUMBER :-- 正常排序[1,2,3,4] -- 必须有order_by
RANK :-- 跳跃排序[1,2,2,4] -- 必须有order_by
DENSE_RANK :-- 密集排序[1,2,2,3] -- 必须有order_by
FIRST :从DENSE_RANK返回的集合中取出排在最前面的一个值的行
LAST :从DENSE_RANK返回的集合中取出排在最后面的一个值的行
FIRST_VALUE :返回组中数据窗口的第一个值
LAST_VALUE :返回组中数据窗口的最后一个值。
三.数学分析函数
STDDEV :计算当前行关于组的标准偏离
STDDEV_POP:该函数计算总体标准偏离,并返回总体变量的平方根
STDDEV_SAMP:该函数计算累积样本标准偏离,并返回总体变量的平方根
VAR_POP :该函数返回非空集合的总体变量(忽略null)
VAR_SAMP :该函数返回非空集合的样本变量(忽略null)
VARIANCE :如果表达式中行数为1,则返回0,如果表达式中行数大于1,则返回VAR_SAMP
COVAR_POP :返回一对表达式的总体协方差
COVAR_SAMP :返回一对表达式的样本协方差
CORR :返回一对表达式的相关系数
CUME_DIST :计算一行在组中的相对位置
NTILE :将一个组分为"表达式"的散列表示(类于Hive的分桶原理)
PERCENT_RANK :和CUME_DIST(累积分配)函数类似
PERCENTILE_DISC :返回一个与输入的分布百分比值相对应的数据值
PERCENTILE_CONT :返回一个与输入的分布百分比值相对应的数据值
RATIO_TO_REPORT :该函数计算expression/(sum(expression))的值,它给出相对于总数的百分比
REGR_ (Linear Regression) Functions :这些线性回归函数适合最小二乘法回归线,有9个不同的回归函数可使用
四.行比较分析函数
LAG :可以访问结果集中的其它行而不用进行自连接 -- 落后 -- lag(xx,1,0)
LEAD :LEAD与LAG相反,LEAD3可以访问组中当前行之后的行 -- 领先 -- lead(xx,1,0)
最后,我自己是一名从事了多年开发的Python老程序员,辞职目前在做自己的Python私人定制课程,今年年初我花了一个月整理了一份最适合2019年学习的Python学习干货,可以送给每一位喜欢Python的小伙伴,想要获取的可以关注我的头条号并在后台私信我:01,即可免费获取。
猜你喜欢
- 2025-05-08 上位机外挂报表第3课---完结篇(上位机软件界面用什么做)
- 2025-05-08 SQL语言包括哪几部分?每部分都有哪些操作关键字?
- 2025-05-08 SQL 高手必备!5 步拆解复杂 SQL 逻辑,轻松驾驭数据分析
- 2025-05-08 如何计算100万个数据的平均值?MySQL的AVG函数了解下
- 2025-05-08 SQL在数据分析中怎么使用(sql 进行数据分析实例)
- 2025-05-08 SQL的GROUP BY语句和聚合函数 详解
- 2025-05-08 如何使用 SQL 视图和子查询进行复杂查询
- 2025-05-08 PostgreSQL 内置函数详解(postgresql切换数据库)
- 2025-05-08 SQL之分组函数(sql分组函数做查询条件)
- 2025-05-08 SQL用了两年多,分享2个最常用的小技巧
- 06-30美国食品标签上的含义(美国食品标志)
- 06-305G 网络如何进行系统消息更新(5g系统升级)
- 06-30如何使用Bulk Product Update批量产品更新将产品信息提交给SAGE
- 06-30什么是VLAN? VLAN基本原理(什么是vlan 其作用是什么)
- 06-30隧道人员定位投屏操作说明(隧道人员定位系统)
- 06-30Grafana可视化平台面板之Gauge仪表和Bar Gauge条形仪表
- 06-30Web Components实践:如何搭建一个框架无关的AI组件库
- 06-30Dify「模板转换」节点终极指南:动态文本生成进阶技巧(附代码)Jinja2引擎解析|6大应用场景实战
- 最近发表
-
- 美国食品标签上的含义(美国食品标志)
- 5G 网络如何进行系统消息更新(5g系统升级)
- 如何使用Bulk Product Update批量产品更新将产品信息提交给SAGE
- 什么是VLAN? VLAN基本原理(什么是vlan 其作用是什么)
- 隧道人员定位投屏操作说明(隧道人员定位系统)
- Grafana可视化平台面板之Gauge仪表和Bar Gauge条形仪表
- Web Components实践:如何搭建一个框架无关的AI组件库
- Dify「模板转换」节点终极指南:动态文本生成进阶技巧(附代码)Jinja2引擎解析|6大应用场景实战
- 为警示“勇闯51区”的年轻人,美军方推特这个玩笑砸了自己的脚
- 威纶通触摸屏与西门子1200通讯符号寻址时,如何导入标签?
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)