hive窗口函数分组排序并取第一个值_Hive窗口函数row number的用法, 你肯定都会吧!...

row_number

前面我们介绍窗口函数的时候说到了窗口函数的使用场景,我们也给它起了一个名字进行区分,通用窗口函数和特殊窗口函数,今天我们就来看一下排序相关的窗口函数,因为是窗口函数,并且我们说它是用来排序的,我们大概也能猜到它就是用来对窗口内的数据进行排序的

其实关于排序我们前面也介绍过order by,sort by 等排序的方式Hive语法之常见排序方式,为什么还有窗口函数进行排序的,因为前面的order by,sort by 等虽然可以排序但是不能给我们返回排序的值(名次),如果你用过mysql 的话,这个时候你就知道写存储过程或者使用自定义变量来完成这个功能,row number 也是一样的道理,可以按照我们自定义的排序规则,返回对应的排序先后顺序的值

所以我们认为row_number是窗口排序函数,但是hive 也没有提供非窗口的排序函数,但是我们前面说过了如果没有窗口的定义中没有partition by 那就是将整个数据输入当成一个窗口,那么这种情况下我们也可以使用窗口排序函数完成全局排序。

测试数据

下面有一份测试数据id,dept,salary,然后我们就使用这份测试数据学习我们的窗口排序函数

1,销售,10000

2,销售,14000

3,销售,10000

4,后端,20000

5,后端,25000

6,后端,32000

7,AI,40000

8,AI,35000

9,AI,60000

10,数仓,20000

11,数仓,30000

12,数仓,32000

13,数仓,42000

create table ods_num_windo

你可能感兴趣的:(hive窗口函数分组排序并取第一个值_Hive窗口函数row number的用法, 你肯定都会吧!...)