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.做运算:看薪水跟上次相比涨了多少

  • 相关阅读:
    Golang Gin 实战(一)| 快速安装入门
    6 款最棒的 Go 语言 Web 框架简介
    Golang教科书般的web框架
    vgo简明教程
    go mod常用命令 已经 常见问题
    线程池原理讲解 Java专题
    Python 3.9安装与使用
    消息队列的基本概念
    实践——GIT安装(2021/05/01)
    vue2.0数据双向绑定原理分析及代码实现
  • 原文地址:https://www.cnblogs.com/TengQiuli/p/13821585.html
Copyright © 2011-2022 走看看