oracle 的lag,LAG函数的使用
該內(nèi)容來自官方翻譯,因?yàn)榻裉炜吹揭粋€(gè)查詢語句中使用該函數(shù),不是太明白用法,這里先簡單了解一下。
LAG是一個(gè)分析函數(shù),主要提供用于同時(shí)訪問多行數(shù)據(jù),且此數(shù)據(jù)不通過自連接獲取。當(dāng)從查詢獲取多行值和一個(gè)位置游標(biāo),LAG會訪問游標(biāo)位置中物理偏移量優(yōu)先的數(shù)據(jù),
offset(偏移量)參數(shù)為一個(gè)大于0的可選整數(shù)值。如果不指定偏移量,默認(rèn)值為1。
當(dāng)offset超過顯示范圍,則顯示選項(xiàng)default的值。如果不指定default值,則默認(rèn)為空。
{RESPECT | IGNORE} NULLS選項(xiàng)決定是否將空值或VALUE_EXPR表達(dá)式的值包含在內(nèi),或?qū)⑦@些值淘汰掉,默認(rèn)為RESPECT NULLS
對于表達(dá)式VALUE_EXPR,不可以在LAG中嵌套使用任何其他的分析函數(shù),但可以使用內(nèi)建函數(shù)。
文檔中給出的列子比較具有代表性: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工作的機(jī)制,因?yàn)楂@取的結(jié)果是多行數(shù)據(jù):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
從上下兩個(gè)查詢結(jié)果不難看出,LAG將查詢的結(jié)果進(jìn)行偏移,其偏移量為1,獲得了上一個(gè)查詢結(jié)果,而第一行記錄(salary=3100)的上一個(gè)查詢不存在的時(shí)候,offset超過了顯示范圍,所以用指定的default值0替代。
總結(jié)
以上是生活随笔為你收集整理的oracle 的lag,LAG函数的使用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 新闻资讯博客小程序源码/支持微信、QQ、
- 下一篇: 我的世界神奇宝贝服务器注册指令,《我的世