Oracle 之Lead()与Lag()

文章介绍了在处理连续事件间隔和比较相邻数据时,如何利用SQL中的lag()和lead()函数。这两个函数分别用于获取当前行之前和之后的行数据,在计算购买间隔、员工工资差距等场景下非常有用。以emp表为例,展示了查询每个员工工资与其相邻员工工资差距的查询代码及其结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 使用场景

实际业务中,企业客户的日志、订单、购买记录等存在多条,在计算频次、购买间隔、忠诚度等指标业务中会需要连续两次购买(活跃)之间的间隔时长数据,以及在工资表中某个员工与上一个或下一个员工工资差距,这个时候就可以用到lag()和lead()函数。

  1. lead()函数和lag()函数

lag(字段,向上取几行,取不到给默认值),lag函数是以当前位置向上去指定几行数据,取不到默认为null,当然也可以自己指定默认值;

lead (字段,向上取几行,取不到给默认值),lag函数是以当前位置向上去指定几行数据,取不到默认为null,当然也可以自己指定默认值;

  1. 案例

以emp表为例:

查询每个员工(id:empno)的上一个员工与下一个员工工资(sal)差距情况

代码如下
select e.EMPNO,e.SAL 员工工资,
       lead(e.SAL,1) over (order by e.SAL desc ) 上一个员工工资,
       lag( e.SAL,1) over (order by e.SAL desc ) 下一个员工工资
from EMP e;
查询结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值