Poszukuję metodologii porównywania różnicy między 2 wierszami w tej samej tabeli. Z tego co tu znalazłem (How to get difference between two rows for a column field?) jest prawie to, co chciałem. Zrobiłem następujący kod:Suma obliczeniowa sql między 2 wierszami
create table #tmpTest
(
id_fund int null,
id_ShareType int null,
ValueDate datetime null,
VarNAV float null,
FundPerf float null,
)
insert into #tmpTest(id_fund, id_ShareType, ValueDate, VarNAV)
values(1,1,'20140101',100)
insert into #tmpTest(id_fund, id_ShareType, ValueDate, VarNAV)
values(1,1,'20140102',20)
update #tmpTest
set hrc.FundPerf = (isnull(hrn.VarNAV, 0) - hrc.VarNAV)/hrc.VarNAV
from #tmpTest hrc
left join #tmpTest hrn on hrn.ValueDate = (select min(ValueDate) from #tmpTest where ValueDate > hrc.ValueDate)
and hrc.id_fund = hrn.id_fund and hrc.id_ShareType = hrn.id_ShareType
Mój problem jest, że wynik mam computing zaczyna się na linii 1, zamiast linii 2.
wynikające z Umowy, w wyniku jestem uzyskanie:
id_fund id_ShareType ValueDate VarNAV FundPerf
------- ------------ ------------------- ------- -----------------------------
1 1 2014-01-01 00:00:00 100 -0.8
1 1 2014-01-02 00:00:00 20 -1
natomiast chciałbym go mieć w ten sposób:
id_fund id_ShareType ValueDate VarNAV FundPerf
------- ------------ ------------------- ------- -----------------------------
1 1 2014-01-01 00:00:00 100 -1
1 1 2014-01-02 00:00:00 20 -0.8
Co jest nie tak z moim podejściem?
Dlaczego nie można użyć 'LAG' i funkcje "LEAD"? – Kermit