Hive窗口函数

发布 : 2016-02-12 分类 : 大数据 浏览 :

数据准备

1
[root@node1 data]# vi win.txt

1
2
3
4
5
6
7
8
9
10
11
12
13
14
cookie1,2015-04-10 10:00:02,url2
cookie1,2015-04-10 10:00:00,url1
cookie1,2015-04-10 10:03:04,1url3
cookie1,2015-04-10 10:50:05,url6
cookie1,2015-04-10 11:00:00,url7
cookie1,2015-04-10 10:10:00,url4
cookie1,2015-04-10 10:50:01,url5
cookie2,2015-04-10 10:00:02,url22
cookie2,2015-04-10 10:00:00,url11
cookie2,2015-04-10 10:03:04,1url33
cookie2,2015-04-10 10:50:05,url66
cookie2,2015-04-10 11:00:00,url77
cookie2,2015-04-10 10:10:00,url44
cookie2,2015-04-10 10:50:01,url55

创建表

1
2
3
4
5
6
CREATE EXTERNAL TABLE win (
cookieid string,
createtime string, --页面访问时间
url STRING --被访问页面
) ROW FORMAT DELIMITED
FIELDS TERMINATED BY ',' ;

查看表结构

1
hive> desc win;

加载本地数据到表中

1
hive> load data local inpath '/opt/modules/hive-1.2.1/data/win.txt' overwrite into table win;

1
hive> load data local inpath '/opt/modules/hive-1.2.1/data/win.txt' overwrite into table win;

LAG

1
2
3
4
LAG(col,n,DEFAULT)用于统计窗口内往上第n行值
第一个参数为列名,
第二个参数为往上第n行(可选,默认为1),
第三个参数为默认值(当往上第n行为NULL时候,取默认值,如不指定,则为NULL)
1
2
3
4
5
6
7
hive> SELECT cookieid,
> createtime,
> url,
> ROW_NUMBER() OVER(PARTITION BY cookieid ORDER BY createtime) AS rn,
> LAG(createtime,1,'1970-01-01 00:00:00') OVER(PARTITION BY cookieid ORDER BY createtime) AS last_1_time,
> LAG(createtime,2) OVER(PARTITION BY cookieid ORDER BY createtime) AS last_2_time
> FROM win;

1
2
3
4
5
6
7
8
9
10
last_1_time: 指定了往上第1行的值,default为'1970-01-01 00:00:00'  
cookie1第一行,往上1行为NULL,因此取默认值 1970-01-01 00:00:00
cookie1第三行,往上1行值为第二行值,2015-04-10 10:00:02
cookie1第六行,往上1行值为第五行值,2015-04-10 10:50:01

last_2_time: 指定了往上第2行的值,为指定默认值
cookie1第一行,往上2行为NULL
cookie1第二行,往上2行为NULL
cookie1第四行,往上2行为第二行值,2015-04-10 10:00:02
cookie1第七行,往上2行为第五行值,2015-04-10 10:50:01
本文作者 : Matrix
原文链接 : https://matrixsparse.github.io/2016/02/12/Hive窗口函数/
版权声明 : 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明出处!

知识 & 情怀 | 二者兼得

微信扫一扫, 向我投食

微信扫一扫, 向我投食

支付宝扫一扫, 向我投食

支付宝扫一扫, 向我投食

留下足迹