oracle 的lag,LAG函数的使用

该内容来自官方翻译,因为今天看到一个查询语句中使用该函数,不是太明白用法,这里先简单了解一下。

5242e148b07d0251d95c087af17dc2b0.gif

LAG是一个分析函数,主要提供用于同时访问多行数据,且此数据不通过自连接获取。当从查询获取多行值和一个位置游标,LAG会访问游标位置中物理偏移量优先的数据,

offset(偏移量)参数为一个大于0的可选整数值。如果不指定偏移量,默认值为1。

当offset超过显示范围,则显示选项default的值。如果不指定default值,则默认为空。

{RESPECT | IGNORE} NULLS选项决定是否将空值或VALUE_EXPR表达式的值包含在内,或将这些值淘汰掉,默认为RESPECT NULLS

对于表达式VALUE_EXPR,不可以在LAG中嵌套使用任何其他的分析函数,但可以使用内建函数。

文档中给出的列子比较具有代表性:SELECT hire_date, last_name, salary,

LAG(salary, 1, 0 ) OVER (ORDER BY hire_date) AS prev_sal

FROM employees

WHERE job_id = 'PU_CLERK'

ORDER BY hire_date;

HIRE_DATE           LAST_NAME                                                                       SALARY   PREV_SAL

------------------- --------------------------------------------------------------------------- ---------- ----------

2003-05-18 00:00:00 Khoo                                                                              3100          0

2005-07-24 00:00:00 Tobias                                                                            2800       3100

2005-12-24 00:00:00 Baida                                                                             2900       2800

2006-11-15 00:00:00 Himuro                                                                            2600       2900

2007-08-10 00:00:00 Colmenares                                                                        2500       2600

如何理解LAG工作的机制,因为获取的结果是多行数据:SQL> select hire_date,last_name,salary from employees where job_id = 'PU_CLERK' order by  hire_date;

HIRE_DATE           LAST_NAME                                                                       SALARY

------------------- --------------------------------------------------------------------------- ----------

2003-05-18 00:00:00 Khoo                                                                              3100

2005-07-24 00:00:00 Tobias                                                                            2800

2005-12-24 00:00:00 Baida                                                                             2900

2006-11-15 00:00:00 Himuro                                                                            2600

2007-08-10 00:00:00 Colmenares                                                                        2500

从上下两个查询结果不难看出,LAG将查询的结果进行偏移,其偏移量为1,获得了上一个查询结果,而第一行记录(salary=3100)的上一个查询不存在的时候,offset超过了显示范围,所以用指定的default值0替代。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值