时间:2021-05-02
Lag和Lead函数可以在一次查询中取出同一字段的前N行的数据和后N行的值。这种操作可以使用对相同表的表连接来实现,不过使用LAG和LEAD有更高的效率。
复制代码 代码如下:
CREATE TABLE salaryByMonth
(
employeeNo varchar2(20),
yearMonth varchar2(6),
salary number
) ;
insert into SALARYBYMONTH (EMPLOYEENO, YEARMONTH, SALARY)
values (1, '200805', 500);
insert into SALARYBYMONTH (EMPLOYEENO, YEARMONTH, SALARY)
values (1, '200802', 150);
insert into SALARYBYMONTH (EMPLOYEENO, YEARMONTH, SALARY)
values (1, '200803', 200);
insert into SALARYBYMONTH (EMPLOYEENO, YEARMONTH, SALARY)
values (1, '200804', 300);
insert into SALARYBYMONTH (EMPLOYEENO, YEARMONTH, SALARY)
values (1, '200708', 100);
commit;
SELECT EMPLOYEENO
,YEARMONTH
,SALARY
,MIN(SALARY) KEEP(DENSE_RANK FIRST ORDER BY YEARMONTH) OVER(PARTITION BY EMPLOYEENO) FIRST_SALARY -- 基比分析 salary/first_salary
,LAG(SALARY, 1, 0) OVER(PARTITION BY EMPLOYEENO ORDER BY YEARMONTH) AS PREV_SAL -- 环比分析,与上个月份进行比较
,LAG(SALARY, 12, 0) OVER(PARTITION BY EMPLOYEENO ORDER BY YEARMONTH) AS PREV_12_SAL -- 同比分析,与上个年度相同月份进行比较
,SUM(SALARY) OVER(PARTITION BY EMPLOYEENO, SUBSTR(YEARMONTH, 1, 4) ORDER BY YEARMONTH RANGE UNBOUNDED PRECEDING) LJ --累计值
FROM SALARYBYMONTH
ORDER BY EMPLOYEENO
,YEARMONTH
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
正在看的ORACLE教程是:OraclePL/SQL单行函数和组函数详解。1 函数是一种有零个或多个参数并且有一个返回值的程序。在SQL中Oracle内建了一
4月3日消息,淘宝最新数据显示,4月1日,湖北农产品在淘宝天猫的销量较3月日均值环比翻倍;湖北小龙虾成交额同比增长339%;湖北莲藕成交额同比增长222%,环比
两幅图,是一组索赔同比、环比数据,第三、四行分别是每个月的索赔同比、环比情况:图二明显要比图一的效果更直观吧?如何去实现这样的效果呢,是本人要讲的内容。
两幅图,是一组索赔同比、环比数据,第三、四行分别是每个月的索赔同比、环比情况:图二明显要比图一的效果更直观吧?如何去实现这样的效果呢,是本人要讲的内容。
两幅图,是一组索赔同比、环比数据,第三、四行分别是每个月的索赔同比、环比情况:图二明显要比图一的效果更直观吧?如何去实现这样的效果呢,是本人要讲的内容。1、选中