SQL-平均每月金额

问题描述 投票:0回答:2

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

表看起来像这样:

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 |
sql average
2个回答
2
投票
GROUP BY MONTH(date)

检查MySQL或PostgreSQL中的date and time函数或PostgreSQL的extract函数。


0
投票

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

SELECT AVG(amount) AS avg_amount, date  
FROM table  
GROUP BY YEAR(date), MONTH(date)
© www.soinside.com 2019 - 2024. All rights reserved.