原始数据:
结果数据:
对比两个图,要是不处理连续性中的重复值,我们直接可以用LEAD函数了事,但处理出来的结果貌似多余。
我的思路是先将原始数据中连续性日期有重复值的处理好,即选择最小的一个,比如2011/01/01和2012/01/01的值是一样,日期又是连续的,所以要去除2012/01/01,保留2011/01/01,让处理出来的截止日期为第4行的日期-1即2012/12/30.
以下是实现代码,有更好更方便的欢迎提出来,共同学习。
/*CREATE TABLE TB(PB_DATE DATE,SAVE_RATE VARCHAR2(10),LEN_RATE VARCHAR2(10));
INSERT INTO TB SELECT DATE'2010-01-01','8%','10%' FROM DUAL;
INSERT INTO TB SELECT DATE'2011-01-01','5%','7%' FROM DUAL;
INSERT INTO TB SELECT DATE