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

函数语法如下:

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()同上楼主就不在此一一举例了,想实际操作的可以测试。

总结:对与解决增长数多少、增长率多少这两个函数运用起来你会发现如此奇妙和方便。

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值