oracle函式之lag和lead

yepkeepmoving發表於2016-11-03
 Lag和Lead分析函式可以在同一次查詢中取出同一欄位的前N行的資料(Lag)和後N行的資料(Lead)作為獨立的列。
 這種操作可以代替表的自聯接,並且LAG和LEAD有更高的效率。

語法格式

    lag(exp_str,offset,defval) over()  
    Lead(exp_str,offset,defval) over()  
    --exp_str要取的列  
    --offset取偏移後的第幾行資料  
    --defval:沒有符合條件的預設值

例項展示:

1)建立測試資料

create table t1(id int,name varchar(30));
insert into t1 values(1,'AAA');
insert into t1 values(2,'BBB');
insert into t1 values(3,'CCC');
insert into t1 values(4,'DDD');
insert into t1 values(5,'EEE');
insert into t1 values(6,'FFF');
commit;
2)lag ...over函式示例
##抽取name列的所有資料,按照倒序排列,然後下沉一行
SQL> select id,name,lag(name,1) over (order by id desc) lag_desc from t1;

     ID NAME                 LAG_DESC
------- -------------------- ------------------------------
      6 FFF
      5 EEE                  FFF
      4 DDD                  EEE
      3 CCC                  DDD
      2 BBB                  CCC
      1 AAA                  BBB

6 rows selected.
3)lead ... over函式示例
##抽取name列的所有資料,按照倒序排列,然後上升一行
SQL> select id,name,lead(name,1) over (order by id desc) lead_desc from t1;    
ID     NAME                 LEAD_DESC
------- -------------------- ------------------------------
      6 FFF                   EEE
      5 EEE                  DDD
      4 DDD                 CCC
      3 CCC                  BBB
      2 BBB                  AAA
      1 AAA

6 rows selected.


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/27067062/viewspace-2127633/,如需轉載,請註明出處,否則將追究法律責任。

相關文章