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)
- 将窗口中的行分成指定数量的近似相等的组,并为每一行返回其组号。
- 示例&