[MySQL] 按日期進行統計(前一天、本周、某一天)

來源:互聯網
上載者:User

標籤:使用   ar   資料   sp   2014   on   log   時間   bs   

在mysql資料庫中,常常會遇到統計當天的內容。
例如,在user表中,日期欄位為:log_time
統計當天

sql語句為:

    select * from user where date(log_time) = curdate();   

curdate()表示當天日期
統計前一天

如果表示前一天的資料,則不能使用curdate()-1,因為當日期為月初時,curdate()-1 日期就不是上一個月的月末日期。

例如:今天是6月1日,理論上curdate()-1為5月31日,但是curdate()-1得到不是5月31日,而是6月0日。那麼統計前一天的日期就不能使用curdate()-1了,mysql資料庫又有一個新方法統計前一天的資料。

統計前一天的日誌sql語句:

    select * from bean where date(log_time) = date_sub(curdate(),interval 1 day); 

括弧中為當天時間的前一天,如果統計前幾天就將括弧中的’1’改成相應的天數。如果要算月或年,直接將day改為month或year即可
統計本周

要求: 統計從昨天開始統計前7天的日誌包括昨天

    select * from user where date(log_time) >= date_sub(curdate(),interval 7 day)   
    and date(log_time) <=  date_sub(curdate(),interval 1 day) 

在網上找的使用week統計一周資訊,只能統計到5天的資訊,不符合要求,所以改用這種方法。
統計某一天

統計曆史某一天的日誌,將date_sub(curdate(),interval 0 day)函數中的curdate()替換為某一天的日期
比如:要統計2012-05-25日期的資訊
date_sub(‘2012-05-25‘,interval 0 day)
關於date_sub()函數的例子:

今天是2013年5月20日。
date_sub(‘2012-05-25‘,interval 1 day) 表示 2012-05-24
date_sub(‘2012-05-25‘,interval 0 day) 表示 2012-05-25
date_sub(‘2012-05-25‘,interval -1 day) 表示 2012-05-26
date_sub(‘2012-05-31‘,interval -1 day) 表示 2012-06-01
date_sub(curdate(),interval 1 day) 表示 2013-05-19
date_sub(curdate(),interval -1 day) 表示 2013-05-21
date_sub(curdate(),interval 1 month) 表示 2013-04-20
date_sub(curdate(),interval -1 month) 表示 2013-06-20
date_sub(curdate(),interval 1 year) 表示 2012-05-20
date_sub(curdate(),interval -1 year) 表示 2014-05-20

[MySQL] 按日期進行統計(前一天、本周、某一天)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.