假设我们有一个名为"transactions"的MySQL表,其中包含日期和金额两列。我们想要按日期分组,并计算在某个特定日期之前的累积金额。
以下是一个解决方案的示例代码:
SELECT t1.date, SUM(t2.amount) AS cumulative_sum
FROM transactions t1
JOIN transactions t2 ON t2.date <= t1.date
WHERE t1.date <= '2022-01-31' -- 某个特定日期
GROUP BY t1.date
ORDER BY t1.date;
以上代码中,我们使用了自连接(self join)的方式来计算累积金额。我们将表"transactions"自连接两次,第一次用于按日期分组,第二次用于计算累积金额。通过将第二个表的日期限制为小于等于第一个表的日期,我们可以计算出该日期之前的累积金额。最后,我们使用GROUP BY按日期分组,并通过ORDER BY按日期排序结果。
请注意,上述代码中的日期条件"t1.date <= '2022-01-31'"是一个示例。您需要根据实际需求将其替换为您想要排除的特定日期。
希望以上解决方案能对您有所帮助!
上一篇:按日期分组的类别中的出现次数统计
下一篇:按日期分组的Pandas