Summary_Oracle lag()/lead() over()分析函数

--lead函数是按id倒序排序把下一行的age记录显示在当前行的列lag,为null显示null
with tmp as(
        select '1' id ,'aa' name ,'22' age from dual union all
        select '2' id ,'bb' name ,'20' age from dual union all
        select '3' id ,'CC' name ,'21' age from dual
)
select a.*,
       lead(age,1) over (order by id desc) lag,
       a.age - lead(age,1) over (order by id desc) lag1
from tmp a;


注意:如果不使用lead()over()函数实现上图查询结果,则需要下面的SQL语句:

        SELECT T1.*,T2.AGE AS LAG,T1.AGE-T2.AGE  AS LAG1 FROM (
        SELECT a.*,ROWNUM AS R1 FROM (SELECT ID,NAME,AGE FROM tmp GROUP BY ID,NAME,AGE ORDER BY ID DESC) a
        ) T1 LEFT JOIN (
        SELECT b.*,ROWNUM-1 AS R2 FROM (SELECT ID,NAME,AGE FROM tmp GROUP BY ID,NAME,AGE ORDER BY ID DESC) b
        ) T2 ON T1.R1=T2.R2 ORDER BY T1.ID DESC;


--lag函数是按id倒序排序把上一行的age记录显示在当前行的列lag,为null显示null
with tmp as(
        select '1' id ,'aa' name ,'22' age from dual union all
        select '2' id ,'bb' name ,'20' age from dual union all
        select '3' id ,'CC' name ,'21' age from dual
)
select a.*,
       lag(age,1) over (order by id desc) lag,
       a.age - lag(age,1) over (order by id desc) lag1

from tmp a;


注意:如果不使用lead()over()函数实现上图查询结果,则需要下面的SQL语句:

        SELECT T1.*,T2.AGE AS LAG,T1.AGE-T2.AGE  AS LAG1 FROM (
        SELECT a.*,ROWNUM-1 AS R1 FROM (SELECT ID,NAME,AGE FROM tmp GROUP BY ID,NAME,AGE ORDER BY ID DESC) a
        ) T1 LEFT JOIN (
        SELECT b.*,ROWNUM AS R2 FROM (SELECT ID,NAME,AGE FROM tmp GROUP BY ID,NAME,AGE ORDER BY ID DESC) b
        ) T2 ON T1.R1=T2.R2 ORDER BY T1.ID DESC;


  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值