Access SQL 中按月份的年初至今摘要

Posted

技术标签:

【中文标题】Access SQL 中按月份的年初至今摘要【英文标题】:Year-To-Date Summary by Month in Access SQL 【发布时间】:2013-06-10 13:42:27 【问题描述】:

鉴于此表,我需要按月生成年初至今的摘要。结果应该有一年中每个月的一行,以及截至该月的一年的运行总计。当谈到 SQL 时,我绝不是新手,但我仍然不知道如何在纯 SQL 中实现这一点。有谁知道如何做到这一点?请注意,它需要与 Microsoft Access SQL 兼容。

projectTitle  | completionDate | amount
---------------------------------------
'Project #1'  | 2013-01-12     | 1234
'Project #2'  | 2013-01-25     | 4567
'Project #3'  | 2013-02-08     | 8901
'Project #4'  | 2013-02-15     | 2345
'Project #5'  | 2013-02-20     | 6789
'Project #6'  | 2013-03-01     | 1234
'Project #7'  | 2013-04-12     | 5678
'Project #8'  | 2013-05-06     | 9012
'Project #9'  | 2013-05-20     | 3456
'Project #10' | 2013-06-18     | 7890
'Project #11' | 2013-08-10     | 1234

预期结果示例

month    | amount
-----------------
'Jan-13' | 5801          -- = Project #1 + Project #2 + Project #3
'Feb-13' | 23836         -- = Project #1 + Project #2 + Project #3 + Project #4 + Project #5
'Mar-13' | 25070         -- ...and so on
'Apr-13' | 30748         
'May-13' | 43216         
'Jun-13' | 51106
'Jul-13' | 51106          
'Aug-13' | 52340

在我的示例输出中,您可能会注意到我包含了 7 月,即使示例表没有 7 月的任何数据。理想情况下,输出仍将包括您在示例输出中看到的 7 月,但如有必要,我可以不用。

【问题讨论】:

【参考方案1】:

我通过使用子查询并为表名使用别名找到了答案。

SELECT FORMAT(t1.completionDate,"mmm-yy") AS [month], (
        SELECT SUM(t2.amount)
        FROM projects AS t2
        WHERE MONTH(t2.completionDate) <= MONTH(t1.completionDate)
    ) AS [amount]
FROM projects AS t1;

【讨论】:

【参考方案2】:

我认为,尝试按月份对其进行分组可能会有所帮助。查看here 以了解如何按月份对其进行分组。 然后您应该能够按月份汇总金额。

希望这个想法对你有所帮助。

萨拉乔格

【讨论】:

对不起,但这没有帮助。我已经可以按月对它进行分组,但问题是每个月都将之前的所有月份都包括在总数中。 您想要一个每月返回的 sql 查询来获取当月完成的所有项目的总数,或者您到底想要什么? 我认为我不能比我在问题中更好地解释它。但是,当查询运行时,它应该每个月都有一行,直到当年的当前月份。每行的金额列应该是当年截至该行月份的所有项目的总和。 我认为这会对你有所帮助:link【参考方案3】:
Select Month(CompletionDate) as MthComplete, Year(CompletionDate) as YrComplete, AMT as Sum(Amount)
From MyTable
Group By Year(CompletionDate), Month(CompletionDate)
Order By Year(CompletionDate), Month(CompletionDate)

您可能需要使用另一列来获取您在输出示例中使用的年/月格式,但这会按照您想要的方式对数据进行分组。

【讨论】:

不幸的是,这不是我想要的。输出的每一行不应该只是那个月的总和,还应该是前几个月的总和。

以上是关于Access SQL 中按月份的年初至今摘要的主要内容,如果未能解决你的问题,请参考以下文章

基于月份的 Oracle SQL 数据迁移行到列因类型而失败

在sql中按月份名称分组

在 SQL 和 Access 中按年份并排数据比较

Access 2010 SQL--在交叉表查询中按聚合函数对行进行排序

access-sql 和 VBA:SUM 当前月份和年份(2017 年 2 月)和当前月份和去年(2016 年 2 月)

计算年初至今重复