此查询提供当年和上一年至今的价格和平方英尺的年初至今数字。这更像是当前年份和上一年的运行总计,在这种情况下,从 1 到 7 等周......(2017 年第 7 周于 2017 年 2 月 19 日结束)本年度和上一年(2016 年第 7 周于 2016 年 2 月 22 日结束)。我使用子查询的原因是因为这是我知道解决这种情况的唯一方法。当然,如果您认为执行此查询有更短、可行的替代方案,请提出建议。
Actual_Sale_Date
保存一周中所有 7 天的数据,但我们在周日截止,这就是为什么 2/22/2016(周日结束 2016 年第 7 周)和 2/19/2017(周日结束 2017 年第 7 周)。
我试过"Actual_Sale_Date" = date_trunc('week', now())::date - 1
这个函数只返回在过去的星期天结束的前一周数据。我看了看,interval
因为dateadd
postgresql 中不存在,但无法解决。
我的查询:
select (money(Sum("Price") / COUNT("Price"))) as "Avg_Value YTD",
Round(Avg("Price"/"Sq_Ft"),+2) as "Avg_PPSF YTD",
(select
(money(Sum("Price") / COUNT("Price"))) from allsalesdata
where "Actual_Sale_Date" >= '01/01/2016' AND "Actual_Sale_Date" < '02/22/2016'
and "Work_ID" = 'SO') AS "Last Year at this time Avg_Value",
(select Round(Avg("Price"/"Sq_Ft"),+2)
from allsalesdata
where "Actual_Sale_Date" >= '01/01/2016' AND "Actual_Sale_Date" < '02/22/2016'
and "Work_ID" = 'SO') AS "Last Year at this time Avg_PPSF"
from allsalesdata
where "Actual_Sale_Date" >= '01/01/2017' AND "Actual_Sale_Date" <'02/20/2017'
and "Work_ID" = 'SO'
样本数据:
Price Sq_Ft Actual_Sale_Date Work_ID
45871 3583 01/15/2016 SO
55874 4457 02/05/2016 SO
88745 4788 02/20/2016 SO
58745 1459 01/10/2016 SO
88749 2145 01/25/2017 SO
74856 1478 01/25/2017 SO
74586 4587 01/31/2017 ABC
74745 1142 02/10/2017 SO
74589 2214 02/19/2017 SO