mysql按照月份统计查询

目标:列出指定日期之间的所有月份。例如:SQL语句列出2019-01-28到2019-12-28 之间的月份

结果如下:
mysql按照月份统计查询_第1张图片
SQL语句:

SELECT DATE_FORMAT( @cdate := DATE_ADD( @cdate, INTERVAL + 1 MONTH ), '%Y-%m' ) AS month_list 
FROM ( SELECT @cdate := DATE_ADD( '2019-12-28', INTERVAL - 12 MONTH ) FROM `tb_user` LIMIT 12 ) t0 
WHERE DATE( @cdate ) <= DATE_ADD( '2019-12-28', INTERVAL - 1 DAY ) 

开发时若要求列出6个月、7个月的数据,就需要将上面的SQL改一下了。写个比较通用的:

 SELECT DATE_FORMAT( @cdate := DATE_ADD( @cdate, INTERVAL + 1 MONTH ), '%Y-%m' ) AS month_list 
FROM ( SELECT @cdate := DATE_ADD( dateStr, INTERVAL - showMonth MONTH ) FROM table_name LIMIT showCount ) t0 
WHERE DATE( @cdate ) <= DATE_ADD( dateStr, INTERVAL - 1 DAY ) 

[注]

dateStr:查询的截止日期,yyyy-MM-dd
showMonth:查询记录数,也就是要显示几个月的记录
showCount:列表数据显示的最大记录数。
table_name :表名。这里特别要注意,表名可以是数据库中任意表,但是表中记录数必须要大于你要查询的月数的值,否则可能会出现查询记录与实际查询记录数不匹配的问题。
  例如user表中有5条记录,但是我要列出12个月的记录来,则查询结果只会最多显示5条记录。

以上仅仅是用sql列出月份,若给出一个需求,需要统计某个日期前的数据,那么就需要将上面sql查询结果作为一个表,用左连接进行查询,注意,查询出的日期结果作为主表。
例:
表:

id      money   create_date
1       10000    2019-10-28
SELECT  tb_cmonth.*, 
SUM(money)
FROM 
(
SELECT DATE_FORMAT( @cdate := DATE_ADD( @cdate, INTERVAL + 1 MONTH ), '%Y-%m' ) AS month_list 
FROM ( SELECT @cdate := DATE_ADD( '2019-12-28', INTERVAL - 12 MONTH ) FROM `tb_user` LIMIT 12 ) t0 
WHERE DATE( @cdate ) <= DATE_ADD( '2019-12-28', INTERVAL - 1 DAY ) 
) tb_cmonth
LEFT JOIN 
`tb_money` ti
ON DATE_FORMAT(ti.CREATE_DATE, '%Y-%m')= tb_cmonth.cmonth
GROUP BY tb_cmonth.cmonth

参考文章:https://blog.csdn.net/u014418725/article/details/80924290
https://blog.csdn.net/tojohnonly/article/details/70056905

如有问题欢迎留言讨论^_^

你可能感兴趣的:(Database)