hive函数 lead()和lag()

本文介绍了SQL中的lead()和lag()函数,这两个函数在面试中常见但在实际业务中可能不常用。通过具体场景展示了如何使用它们获取数据表中当前行的前后数据,特别是在按特定字段分组时的应用。文章还提及了开窗函数的基础知识,并指出在用户分组情况下,lead()和lag()函数的实用性更强。
摘要由CSDN通过智能技术生成

lead()函数和lag()这两个在实际业务中其实用的并没有那么多,不过在sql的面试当中倒是经常出现需要用到lead()和lag()这两个函数的问题,且通常使用这个函数的案例其实都是取连续的日期,之前硬是靠自关联写了一大堆sql写出来的(汗),今天突然发现了这两个函数,就正好写一下吧使用.

lead()函数里面可以输入三个参数:(字段,向前行数,值如果为null的话的补充值)

不过这两个一个是取前一条数据,一个是取后一条,我这里拿具体的例子来写一下吧

场景1:

select 
 day_id as ss
,lead(day_id,1,null) over(order by day_id) etime
from imedw.dim_pub_date

这里day_id是一个具体日期,over开窗函数里没有加distribute by 字段

这样的话etime就是当前行的上一行

场景2:

select 
 day_id as ss
,lead(day_id,1,null) over(distribute by user_id order by day_id) etime
from imedw.dim_pub_date

这样的话,就在over里面进行了分组操作,即把每一个user_id看做一个整体,只取单个user的向前一条数据,你可以理解为,场景二是场景一的细化,把每一个user_id拆成了一个场景一

这里涉及一点开窗的知识.

具体工作当中,还是场景2更常见一些

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值