Jika Anda menggunakan MySQL 8, Anda dapat menggunakan fungsi jendela
untuk membuat produk kumulatif. Sayangnya, tidak ada PROD()
agregat / fungsi jendela dalam basis data SQL apa pun yang saya ketahui, tetapi Anda dapat menirunya menggunakan EXP(SUM(LOG(factor)))
:
SELECT
quote_date,
security_id,
tr,
1000 * (EXP(SUM(LOG(1 + COALESCE(tr, 0)))
OVER (PARTITION BY security_id ORDER BY quote_date)))
AS accum_index
FROM stock_prices