oracle中LAG函数怎么用

52次阅读
没有评论

共计 1489 个字符,预计需要花费 4 分钟才能阅读完成。

这篇文章给大家分享的是有关 oracle 中 LAG 函数怎么用的内容。丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,一起跟随丸趣 TV 小编过来看看吧。

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

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;

------------------- --------------------------------------------------------------------------- ---------- ---------- 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 替代。

感谢各位的阅读!关于“oracle 中 LAG 函数怎么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-24发表,共计1489字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)