ORALCE函数:LAG()和LEAD() 分析函数详解

Lag和Lead分析函数可以在同一次查询中取出同一字段的前N行的数据(Lag)和后N行的数据(Lead)作为独立的列。

在实际应用当中,若要用到取今天和昨天的某字段差值时,Lag和Lead函数的应用就显得尤为重要。当然,这种操作可以用表的自连接实现,但是LAG和LEAD与left join、rightjoin等自连接相比,效率更高,SQL更简洁。下面我就对这两个函数做一个简单的介绍。

 

函数语法如下:

lag(exp_str,offset,defval) over(partion by ..order by …)

lead(exp_str,offset,defval) over(partion by ..order by …)

其中exp_str是字段名

     Offset是偏移量,即是上1个或上N个的值,假设当前行在表中排在第5行,则offset 为3,则表示我们所要找的数据行就是表中的第2行(即5-3=2)。

     Defval默认值,当两个函数取上N/下N个值,当在表中从当前行位置向前数N行已经超出了表的范围时,lag()函数将defval这个参数值作为函数的返回值,若没有指定默认值,则返回NULL,那么在数学运算中,总要给一个默认值才不会出错。


完整例子:

1.数据库中的原始数据


ORALCE函数:LAG()和LEAD() 分析函数详解_第1张图片

2.对SAL列:取上一个SAL列作为单独的列,若不指定默认值,则默认值为NULL

ORALCE函数:LAG()和LEAD() 分析函数详解_第2张图片

3.对SAL列:取上一个SAL列作为单独的列,指定默认值为0

ORALCE函数:LAG()和LEAD() 分析函数详解_第3张图片

4.对SAL列:取下一个SAL列作为单独的列,指定默认值为0

ORALCE函数:LAG()和LEAD() 分析函数详解_第4张图片

5.做运算:看薪水跟上次相比涨了多少

ORALCE函数:LAG()和LEAD() 分析函数详解_第5张图片


你可能感兴趣的:(Oracle,11g)