zoukankan      html  css  js  c++  java
  • 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.数据库中的原始数据


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

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

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

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

  • 相关阅读:
    创建基于 SQL Server 表的外部内容类型
    symfony入门之 app/console 命令
    git上传代码到github
    ubuntu下配置apache虚拟主机
    ubuntu14.04下解决编辑器无法输入中文
    PHP把域名解析为站点IP
    mysql平常总结
    php防sql注入函数
    常用的正则检测总结
    redis缓存注意事项
  • 原文地址:https://www.cnblogs.com/TengQiuli/p/13821585.html
Copyright © 2011-2022 走看看