oracle 统计分析函数 lead
语法结构:
lead(value_expr [,offset][,default])
over([query_partition_clause] order by Order_by_clause)
参数说明:
value_expr
值表达式,通常是字段,也可是是表达式。value_expr本身不支持分析函数,也就是lead不支持多层调用。
offset
偏移,应该是很熟悉的数学概念了,或者是相对偏移,表格来开当前行的第offset行,如果offset是整数就表示是顺序下的前第n行,如果是负数就是往后第n行。
如果不提供这个参数,就是默认为1.
default
默认值,如果没有找到,应该返回什么值的意思,有点类似nvl(col,value)。如果没有设置,且找不到,那么就返回Null
over 可以简单地翻译为在什么。。。的基础之上
query_partition_clause
分区语句,对结果集合分区的语句,是可选的,如果没有就是所有的一个分区。
Order_by_clause 排序语句 必须需要 ,形如order by xxx desc/asc
解释示例:
SQL> select *
from test_value;
MONS
JJR
CJL
CJJE
---------- ----------
----------
----------
200801
LZF
250
1999
200802
LZF
200
2000
200803
LZF
300
1000
200804
LZF
23
189
200805
LZF
356
456
200806
LZF
100
200
200807
LZF
600
700
200808
LZF
23
123
200809
LZF
400
500
9 rows
selected
SQL>
SQL> select rownum 序号,Mons,cjl
cjl_01,
2
lead(cjl,1) over (order by mons desc)
cjl_02,
3
lead(cjl,2) over (order by mons desc)
cjl_03,
4
lead(cjl,3) over (order by mons desc)
cjl_04,
5
lead(cjl,4) over (order by mons desc)
cjl_05,
6
lead(cjl,5) over (order by mons desc)
cjl_06,
7
lead(cjl,6) over (order by mons desc)
cjl_07,
8
lead(cjl,7) over (order by mons desc)
cjl_08,
9
lead(cjl,8) over (order by mons desc)
cjl_09
10 from
test_value
序号 MONS
CJL_01 CJL_02
CJL_03 CJL_04
CJL_05 CJL_06
CJL_07 CJL_08
CJL_09
---------- ----------
---------- ---------- ---------- ---------- ---------- ---------- ----------
----------
----------
9 200809
400
23
600
100
356
23
300
200
250
8 200808
23
600
100
356
23
300
200 250
7 200807
600
100
356
23
300
200
250
6 200806
100
356
23
300
200
250
5 200805
356
23
300
200
250
4 200804
23
300
200
250
3 200803
300
200
250
2 200802
200
250
1 200801
250
实践使用示例:
select id,lead(id,1)over(partition by call_req_id order by
call_req_id ,id),type,analyst,time_stamp from act_log order by call_req_id
,id
分享到:
相关推荐
Oracle数据仓库实践 owb安装及使用中的一些笔记
Oracle SQL最佳实践
oracle ASM 最佳实践,绝对权威的文档,不能错过
Oracle运维最佳实践-下.pdf 带书签 运维必备经验
Oracle运维最佳实践-下.pdf 带书签 运维必备经验
Oracle PLSQL最佳实践 第二版
Oracle数据库安全实践和系统优化;对于ORALCE 系统的完全性做了特别的说明
高级Oracle DBA最佳实践
10年老DBA沥血心得
oracle 19c数据库参数优化最佳实践
Oracle运维最佳实践,大牛们的经验总结
这种操作可以使用对相同表的表连接来实现,不过使用LAG和LEAD有更高的效率。 代码如下:CREATE TABLE salaryByMonth( employeeNo varchar2(20), yearMonth varchar2(6), salary number) ;insert into ...
是自已做的数据库安全性实践,环境是oracle,希望大家喜欢
经典分享:Oracle 安全之实践入门篇 议程 我们身边的安全问题 发现、收集、侦测 安全加固(三板斧) 1)OS安全加固 2)Oracle 网络加固 3)RDBMS 安全加固 N)... 其他、更多Oracle安全功能选件 演示
Oracle 9i Client (Oracle 9i 客户端) 简化版 (不安装Oracle客户端,也可以使用PLSQL Developer 不用安装Oracle客户端也可以使用PLSQL Developer 绿色! 安全! 轻便! 可靠! 1、本软件可作为简单的Oracle9i客户端...
分区表对于提高大表的访问性能会有很大的帮助
1、Oracle 10g数据仓库实践--数据仓库基础.pdf 2、Oracle 10g数据仓库实践--总体方案.pdf 3、Oracle 10g数据仓库实践--方案的总体优势.pdf 4、Oracle 10g数据仓库实践--数据仓库工具的选择及准备.pdf 5、Oracle ...
Oracle PLSQL编程最佳实践中文版