查看原文
其他

SQL分析函数,看这一篇就够了

The following article is from 数据仓库与Python大数据 Author 大圣归来

数据库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)





Tips:公众号后台回复“666”,即可领取阿里巴巴大数据pdf资料。


往期推荐

前方高能 | HDFS 的架构,你吃透了吗?

大数据文章合集-数据仓库与Python大数据

谈谈大数据环境下数据质量指标体系

基于Flink构建实时数据仓库.ppt

架构师 | 数据仓库建设灵魂10问

构建与优化数据仓库架构与模型设计

用户画像 | 标签数据存储之Hive真实应用

ClickHouse在B站用户分析实战.PPT

Hbase、Kudu和ClickHouse全视角对比

SQL 窗口函数的优化和执行

用户画像 | 三大标签、八大模块与实践落地

华为数据治理实践

如何搭建一套业务、数据一体化的数据指标体系

Hadoop平台进阶之路 | HDFS NameNode性能优化实践

基于Binlog实时同步数据仓库问题总结

大数据平台数据治理与建设.PPT(90页)

用户画像

附PPT|2020年总结实时数仓最新架构图

Flink SQL 在字节跳动的优化与实践

美团酒旅数据治理实践

干货 | 数据标签体系搭建


欢迎加入大数据|数仓技术交流群

扫码加技术群,备注:数据,加入高手如云


您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存