Oracle的LAG和LEAD分析函数
Lag函数可以在一次查询中取出当前行的同一字段的前面第N行的数据。
Lead函数可以在一次查询中取出当前行的同一字段的后面第N行的值。
lead 和lag 的语法类似以下以lag为例进行讲解!
lag(exp_str,offset,defval) over()
讲解:exp_str-需要查询偏移的字段(可以是表达式,不支持聚合函数)
offset:偏移量(即:数据偏移的行数)
defval:偏移量位null时,替换的值
select lead(ename)over( order by null) as l,ename,empno from emp;
select lead(sal-2000)over(order by null)as l,sal,empno from emp;--偏移值是表达式
select lead(ename,4)over( order by null) as l,ename,empno from emp;--偏移量是2
select lead(ename,4,'hello world')over( order by null) as l,ename,empno from emp;--偏移值是null 的情况
select lag(ename)over( order by null) as l,ename,empno from emp;
select lag(sal-2000)over(order by null)as l,sal,empno from emp;--偏移值是表达式
select lag(ename,4)over( order by null) as l,ename,empno from emp;--偏移量是2
select lag(ename,4,'hello world')over( order by null) as l,ename,empno from emp;--偏移值是null 的情况
本文介绍了Oracle数据库中的LAG和LEAD分析函数。LAG函数用于获取当前行前N行的数据;LEAD函数用于获取当前行后N行的数据。文章详细解释了这两个函数的语法及使用方法,并通过实例展示了如何在查询中应用这些函数。
3839

被折叠的 条评论
为什么被折叠?



