oracle中LAG函数怎么用-创新互联

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

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:空间域名、网络空间、营销软件、网站建设、神木网站维护、网站推广。

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

oracle中LAG函数怎么用

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

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

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


名称栏目:oracle中LAG函数怎么用-创新互联
URL地址:http://myzitong.com/article/csshpd.html