SQL-平均每月金额

时间:2020-06-05 19:48:47

标签: sql average

我有一个带有“金额”和“日期”列的表格,我想按月显示平均值。

该表如下所示:

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 |

2 个答案:

答案 0 :(得分:2)

GROUP BY MONTH(date)

在MySQL或PostgreSQL date and time函数中检出extract函数。

答案 1 :(得分:0)

我喜欢TOvidiu的答案,但这仅在您拥有单年数据的情况下才有效。我建议

SELECT AVG(amount) AS avg_amount, date  
FROM table  
GROUP BY YEAR(date), MONTH(date)
相关问题