我有一个带有“金额”和“日期”列的表,我想按月显示平均值。
表看起来像这样:
amount | date |
100 | 2017-04-22 20:39:24 |
300 | 2017-04-25 16:14:08 |
200 | 2017-04-28 17:51:16 |
100 | 2017-05-29 05:46:42 |
100 | 2017-05-08 16:15:13 |
100 | 2017-05-09 22:06:45 |
400 | 2017-06-10 10:57:34 |
500 | 2017-06-11 15:57:14 |
900 | 2017-06-14 16:02:36 |
这是我所拥有的:
SELECT AVG(amount) AS avg_amount, date
FROM table
GROUP BY date
它按天显示平均值,因此最终看起来与第一个表完全相同,但是没有小时/分钟/秒部分,而我希望它看起来像这样:
avg_amount | date |
200 | April |
100 | May |
600 | June |
GROUP BY MONTH(date)
检查MySQL或PostgreSQL中的date and time函数或PostgreSQL的extract函数。
我喜欢TOvidiu的答案,但这仅在您拥有单年数据的情况下才有效。我建议
SELECT AVG(amount) AS avg_amount, date
FROM table
GROUP BY YEAR(date), MONTH(date)