Mysql中按月和日為組group並進行統計排序order

來源:互聯網
上載者:User

在資料庫中我們經常用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      8320

2014       2      5837

2014       3     25069

2014       4     29820

2014       5     25060

2014       6     17615

2014       7         1

2013       1      9114

2013       2      4258

方法二:利用 MySql內建字串串連函數 CONCAT(str1, str2, ...,str3) 。

SELECT  CONCAT(YEAR(established_time),',',MONTH( established_time)) AS data_time ,COUNT(*) AS num   FROM `table_record`   #group by data_time  GROUP BY YEAR(established_time) DESC,MONTH( established_time)

本欄目更多精彩內容:http://www.bianceng.cn/database/MySQL/

效果:

data_time     num

---------  --------

2014,1         8320

2014,2         5837

2014,3        25069

2014,4        29910

2014,5        25018

2014,6        17347

2014,7            1

2013,1         9114

2013,2         4258

2013,3         8047

注意這裡不要用:

SELECT  YEAR(established_time)+MONTH( established_time) as data_time  

這是錯誤的,它會造成2010+1=2011的這樣的錯誤。

此外,若僅僅用下面語句,是統計的是多年來每月的資料。

SELECT  MONTH(established_time) AS 'month' , COUNT(*) AS 'count' FROM `tb_gongshangju_record_beijing` GROUP BY  MONTH(established_time) DESC

效果如下:

month   count

------  --------

12     44952

11     49720

10     38587

9     48967

8     52874

7     54082

6     69532

5     76999

4     87289

3     85249

2     39997

1     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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.