日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

oracle 的lag,LAG函数的使用

發布時間:2023/12/15 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle 的lag,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,LAG函数的使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。