Mysql中按月和日为组group并进行统计排序order2014-10-28在数据库中我们经常用sql语句对表进行简单的统计排序,对于日期字段,我们可以简单的对其进行order。对于复杂一点的可以按日期中的年,月,日分别进行group,order。按年份进行group,统计排序:SELECT YERA(established_time) ,COUNT(*) AS num <span style="font-size: 13.75px; font-family: Arial, Helvetica, sans-serif;">FROM `table_record` GROUP BY YEAR (established_time)</span> 按月份进行group,统计排序:方法一:简单实用
SELECT YEAR(established_time) AS "year" , MONTH(established_time) AS "month" , COUNT(*) AS "count" FROM `table_record` GROUP BY YEAR (established_time) DESC, MONTH(established_time)
效果:year month count------ ------ -------2014 1 83202014 2 58372014 3 250692014 4 298202014 5 250602014 6 176152014 7 12013 1 91142013 2 4258方法二:利用 MySql内置字符串连接函数 CONCAT(str1, str2, ...,str3) 。
SELECTCONCAT(YEAR(established_time),",",MONTH( established_time)) AS data_time ,COUNT(*) AS num FROM `table_record` #group by data_timeGROUP BY YEAR(established_time) DESC,MONTH( established_time)
本栏目更多精彩内容:http://www.bianceng.cn/database/MySQL/效果:data_time num--------- --------2014,1 83202014,2 58372014,3 250692014,4 299102014,5 250182014,6 173472014,7 12013,1 91142013,2 42582013,3 8047注意这里不要用:SELECT YEAR(established_time)+MONTH( established_time) as data_time 这是错误的,它会造成2010+1=2011的这样的错误。此外,若仅仅用下面语句,是统计的是多年来每月的数据。
SELECTMONTH(established_time) AS "month" , COUNT(*) AS "count" FROM `tb_gongshangju_record_beijing` GROUP BYMONTH(established_time) DESC
效果如下:month count------ --------12 4495211 4972010 385879 489678 528747 540826 695325 769994 872893 852492 399971 49017(NULL) 34456按日期day进行group,统计排序
SELECT YEAR(established_time) AS "year" , MONTH(established_time) AS "month" ,DAY(established_time) AS "day", COUNT(*) AS "count" FROM `table_record` WHERE table_record.`established_time` >= "2014-01-01"GROUP BY YEAR (established_time) DESC, MONTH(established_time) DESC ,DAY(established_time) DESC