取上一行的某个字段值增加到当前行(目标对象为整个结果集)
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,那么在数学运算中,总要给一个默认值才不会出错
SELECT id,sex,name,lag(name,1,0) OVER(PARTITION BY sex ORDER BY id ASC)
from PDATA.stu
根据sex 分组,组内根据id排序,lag(name,1,0)取上一行数据的name增加到当前行,组内第一行默认为null
lead含义相同,只不过是向下偏移,其实通过lag组内排序反过来(ASC–>DESC)即与lead结果相同