我需要按产品计算复利,其中利率可能因年份而异。
简化表如下。initial_value
是第一年开始时产品的价值,final_value
是相应年末的包括利息的价值。
product year initial_value interest final_value
a 1 10000 0.03 10,300.00
a 2 0.02 10,506.00
a 3 0.01 10,611.06
b 1 15000 0.04 15,600.00
b 2 0.06 16,536.00
b 3 0.07 17,693.52
重新创建表:
CREATE TABLE temp (year INTEGER, product CHARACTER,
initial_value DECIMAL(10,2), interest DECIMAL(10,2));
INSERT INTO temp VALUES (1, 'a', 10000, 0.03);
INSERT INTO temp VALUES (2, 'a', 0, 0.02);
INSERT INTO temp VALUES (3, 'a', 0, 0.01);
INSERT INTO temp VALUES (1, 'b', 15000, 0.04);
INSERT INTO temp VALUES (2, 'b', 0, 0.06);
INSERT INTO temp VALUES (3, 'b', 0, 0.07);
以product = a为例,第3年的数字应计算为10000 * (1+0.03) * (1+0.02) * (1+0.01)
产品的年份和数量可能会有所不同,因此我想避免按年份转置数据,但遗憾的是无法想到另一种方法来跨行相乘以获得所需的结果。