mysql擷取目前時間,前一天,後一天

來源:互聯網
上載者:User

標籤:and   規範   mysq   字元   mysql   interval   date   l資料庫   項目   

  負責的項目中,使用的是mysql資料庫,頁面上要顯示當天所註冊人數的數量,擷取當前的年月日,我使用的是 CURDATE(),

錯誤的sql語句

  eg:SELECT COUNT(*) FROM USER WHERE registerDate >= CURDATE() AND registerDate < CURDATE()+1;

  雖然 擷取到的數量在測試環境中是正確的,但在發布到線上的時候,發現有的時候資料是查詢不到,數量為0,因此,就上網查詢是不是CURDATE()+1不規範,發現mysql官網也是不承認時間直接相加減的,雖然會將目前時間轉換為20160802,這時候就是比較這一串字元,mysql官網是不承認用這種方式比較時間大小的,因此:

正確的sql語句

  eg:SELECT COUNT(*) FROM USER WHERE registerDate >= CURDATE() AND registerDate < DATE_SUB(CURDATE(),INTERVAL -1 DAY); 此時,就用到了DATE_SUB()這個函數,用法舉例:

  

今天是2016年08月01日。

date_sub(‘2016-08-01‘,interval 1 day) 表示 2016-07-31 date_sub(‘2016-08-01‘,interval 0 day) 表示 2016-08-01 date_sub(‘2016-08-01‘,interval -1 day) 表示 2016-08-02
date_sub(curdate(),interval 1 day) 表示 2016-07-31 date_sub(curdate(),interval -1 day) 2016-08-02 date_sub(curdate(),interval 1 month) 表示 2016-07-01 date_sub(curdate(),interval -1 month) 表示 2016-09-01 date_sub(curdate(),interval 1 year) 表示 2015-08-01 date_sub(curdate(),interval -1 year) 表示 2017-08-01

 

備忘:

SELECT NOW(),CURDATE(),CURTIME()

結果類似:

NOW() CURDATE() CURTIME()
2016-08-01 16:25:46 2016-08-01 16:25:46

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.