Oracle 之Lead()与Lag()

  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;
查询结果

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值