日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Hive分析窗口函数: LAG、LEAD、FIRST_VALUE、LAST_VALUE

發(fā)布時(shí)間:2023/12/20 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Hive分析窗口函数: LAG、LEAD、FIRST_VALUE、LAST_VALUE 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

目錄

1.數(shù)據(jù)準(zhǔn)備

1.1數(shù)據(jù)格式

1.2創(chuàng)建表

2.LAG

2.1函數(shù)說明

2.2函數(shù)使用

2.3 查詢結(jié)果

2.4 結(jié)果說明

3. LEAD

3.1 函數(shù)說明

3.2 函數(shù)使用

3.3 查詢結(jié)果

4.?FIRST_VALUE

4.1? 函數(shù)說明

4.2 函數(shù)使用

5.?LAST_VALUE

5.1 函數(shù)說明

5.2 函數(shù)使用

5.3 查詢結(jié)果

5.4 取分組內(nèi)最后一個(gè)值

5.6 查詢結(jié)果


1.數(shù)據(jù)準(zhǔn)備

1.1數(shù)據(jù)格式

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創(chuàng)建表

use cookie; drop table if exists cookie4; create table cookie4(cookieid string, createtime string, url string) row format delimited fields terminated by ','; load data local inpath "/home/hadoop/cookie4.txt" into table cookie4; select * from cookie4;

2.LAG

2.1函數(shù)說明

LAG(col,n,DEFAULT) 用于統(tǒng)計(jì)窗口內(nèi)往上第n行值

  • 第一個(gè)參數(shù)為列名,
  • 第二個(gè)參數(shù)為往上第n行(可選,默認(rèn)為1),
  • 第三個(gè)參數(shù)為默認(rèn)值(當(dāng)往上第n行為NULL時(shí)候,取默認(rèn)值,如不指定,則為NULL)

2.2函數(shù)使用

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 cookie.cookie4;

2.3 查詢結(jié)果

2.4 結(jié)果說明

last_1_time: 指定了往上第1行的值,default為'1970-01-01 00:00:00' cookie1第一行,往上1行為NULL,因此取默認(rèn)值 1970-01-01 00:00:00cookie1第三行,往上1行值為第二行值,2015-04-10 10:00:02cookie1第六行,往上1行值為第五行值,2015-04-10 10:50:01 last_2_time: 指定了往上第2行的值,為指定默認(rèn)值cookie1第一行,往上2行為NULLcookie1第二行,往上2行為NULLcookie1第四行,往上2行為第二行值,2015-04-10 10:00:02cookie1第七行,往上2行為第五行值,2015-04-10 10:50:01

3. LEAD

3.1 函數(shù)說明

與LAG相反 ,LEAD(col,n,DEFAULT) 用于統(tǒng)計(jì)窗口內(nèi)往下第n行值

  • 第一個(gè)參數(shù)為列名,
  • 第二個(gè)參數(shù)為往下第n行(可選,默認(rèn)為1),
  • 第三個(gè)參數(shù)為默認(rèn)值(當(dāng)往下第n行為NULL時(shí)候,取默認(rèn)值,如不指定,則為NULL)

3.2 函數(shù)使用

select cookieid, createtime, url, row_number() over (partition by cookieid order by createtime) as rn, LEAD(createtime,1,'1970-01-01 00:00:00') over (partition by cookieid order by createtime) as next_1_time, LEAD(createtime,2) over (partition by cookieid order by createtime) as next_2_time from cookie.cookie4;

3.3 查詢結(jié)果

4.?FIRST_VALUE

4.1? 函數(shù)說明

取分組內(nèi)排序后,截止到當(dāng)前行,第一個(gè)值

4.2 函數(shù)使用

select cookieid, createtime, url, row_number() over (partition by cookieid order by createtime) as rn, first_value(url) over (partition by cookieid order by createtime) as first1 from cookie.cookie4;

4.3 查詢結(jié)果

5.?LAST_VALUE

5.1 函數(shù)說明

取分組內(nèi)排序后,截止到當(dāng)前行,最后一個(gè)值

5.2 函數(shù)使用

select cookieid, createtime, url, row_number() over (partition by cookieid order by createtime) as rn, last_value(url) over (partition by cookieid order by createtime) as last1 from cookie.cookie4;

5.3 查詢結(jié)果

5.4 取分組內(nèi)最后一個(gè)值

查詢語句

select cookieid, createtime, url, row_number() over (partition by cookieid order by createtime) as rn,LAST_VALUE(url) over (partition by cookieid order by createtime) as last1,FIRST_VALUE(url) over (partition by cookieid order by createtime desc) as last2 from cookie.cookie4 order by cookieid,createtime;

5.6 查詢結(jié)果

總結(jié)

以上是生活随笔為你收集整理的Hive分析窗口函数: LAG、LEAD、FIRST_VALUE、LAST_VALUE的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。