Hive窗口函数整理
发布时间:2024年01月17日
Hive 中的窗口函数允许你在结果集的一个特定“窗口”内对行进行计算。这些窗口可以是物理的(基于行在数据中的实际位置)或逻辑的(基于行的一些排序标准)。窗口函数在处理排名、计算累计和或计算移动平均值等问题时特别有用。
以下是一些 Hive 中的常见窗口函数:
-
ROW_NUMBER()
- 为窗口中的每一行分配一个唯一的整数编号。
- 示例:
ROW_NUMBER() OVER (ORDER BY column_name)
-
RANK()
- 为窗口中的每一行分配一个唯一的排名,对于并列的值会有相同的排名,并且会留下一些排名的间隙。
- 示例:
RANK() OVER (ORDER BY column_name)
-
DENSE_RANK()
- 与 RANK() 类似,但不会留下排名间隙。
- 示例:
DENSE_RANK() OVER (ORDER BY column_name)
-
NTILE(n)
- 将窗口中的行分成指定数量的近似相等的组,并为每一行返回其组号。
- 示例:
NTILE(4) OVER (ORDER BY column_name)
-
LAG(column, n, default)
- 返回当前行之前的第 n 行的指定列的值。如果不存在这样的行,则返回默认值。
- 示例:
文章来源:https://blog.csdn.net/yang1015661763/article/details/135607207
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:chenni525@qq.com进行投诉反馈,一经查实,立即删除!