oracle中LAG函数怎么用
这篇文章给大家分享的是有关oracle中LAG函数怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
该内容来自官方翻译,因为今天看到一个查询语句中使用该函数,不是太明白用法,这里先简单了解一下。
LAG是一个分析函数,主要提供用于同时访问多行数据,且此数据不通过自连接获取。当从查询获取多行值和一个位置游标,LAG会访问游标位置中物理偏移量优先的数据,
offset(偏移量)参数为一个大于0的可选整数值。如果不指定偏移量,默认值为1。
当offset超过显示范围,则显示选项default的值。如果不指定default值,则默认为空。
{RESPECT | IGNORE} NULLS选项决定是否将空值或VALUE_EXPR表达式的值包含在内,或将这些值淘汰掉,默认为RESPECT NULLS
对于表达式VALUE_EXPR,不可以在LAG中嵌套使用任何其他的分析函数,但可以使用内建函数。
文档中给出的列子比较具有代表性:
SELECThire_date,last_name,salary,LAG(salary,1,0)OVER(ORDERBYhire_date)ASprev_salFROMemployeesWHEREjob_id='PU_CLERK'ORDERBYhire_date;HIRE_DATELAST_NAMESALARYPREV_SAL------------------------------------------------------------------------------------------------------------------2003-05-1800:00:00Khoo310002005-07-2400:00:00Tobias280031002005-12-2400:00:00Baida290028002006-11-1500:00:00Himuro260029002007-08-1000:00:00Colmenares25002600
如何理解LAG工作的机制,因为获取的结果是多行数据:
SQL>selecthire_date,last_name,salaryfromemployeeswherejob_id='PU_CLERK'orderbyhire_date;HIRE_DATELAST_NAMESALARY--------------------------------------------------------------------------------------------------------2003-05-1800:00:00Khoo31002005-07-2400:00:00Tobias28002005-12-2400:00:00Baida29002006-11-1500:00:00Himuro26002007-08-1000:00:00Colmenares2500
从上下两个查询结果不难看出,LAG将查询的结果进行偏移,其偏移量为1,获得了上一个查询结果,而第一行记录(salary=3100)的上一个查询不存在的时候,offset超过了显示范围,所以用指定的default值0替代。
感谢各位的阅读!关于“oracle中LAG函数怎么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。