使用场景
实际业务中,企业客户的日志、订单、购买记录等存在多条,在计算频次、购买间隔、忠诚度等指标业务中会需要连续两次购买(活跃)之间的间隔时长数据,以及在工资表中某个员工与上一个或下一个员工工资差距,这个时候就可以用到lag()和lead()函数。
lead()函数和lag()函数
lag(字段,向上取几行,取不到给默认值),lag函数是以当前位置向上去指定几行数据,取不到默认为null,当然也可以自己指定默认值;
lead (字段,向上取几行,取不到给默认值),lag函数是以当前位置向上去指定几行数据,取不到默认为null,当然也可以自己指定默认值;
案例
以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;
查询结果
