函数语法如下:
lag(exp_str,offset,defval) over(order by)
lead(exp_str,offset,defval) over(order by)
其中exp_str是字段名
Offset是偏移量,即是上1个或上N个的值,假设当前行在表中排在第5行,则offset 为3,则表示我们所要找的数据行就是表中的第2行(即5-3=2)。
Defval默认值,当两个函数取上N/下N个值,当在表中从当前行位置向前数N行已经超出了表的范围时,lag()函数将defval这个参数值作为函数的返回值,若没有指定默认值,则返回NULL,那么在数学运算中,总要给一个默认值才不会出错。
例子
- 数据库原数据
SELECT grade,losal,hisal FROM SALGRADE s ORDER BY s.HISAL
- 对SAL列:取上一个SAL列作为单独的列,若不指定默认值,则默认值为NULL
SELECT grade,losal,hisal,lag(s.HISAL) over(ORDER BY s.HISAL) lasthisal FROM SALGRADE s ORDER BY s.HISAL
- 对SAL列:取上一个SAL列作为单独的列,指定默认值为0
SELECT grade,losal,hisal,lag(s.HISAL,1,0) over(ORDER BY s.HISAL) lasthisal FROM SALGRADE s ORDER BY s.HISAL
- 做运算:跟上次相比涨了多少
SELECT grade,losal,hisal,lasthisal,hisal-lasthisal as addhisal
FROM (select grade,losal,hisal ,lag(s.HISAL,1,0) over(ORDER BY s.HISAL) lasthisal FROM SALGRADE s)
ORDER BY HISAL
lead()同上楼主就不在此一一举例了,想实际操作的可以测试。
总结:对与解决增长数多少、增长率多少这两个函数运用起来你会发现如此奇妙和方便。