mysql獲取當前時間,前一天,後一天

mysql獲取當前時間,前一天,後一天   負責的項目中,使用的是mysql數據庫,頁面上要顯示當天所註冊人數的數量,獲取當前的年月日,我使用的是 CURDATE(),mysql

錯誤的sql語句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()這個函數,用法舉例:date

  

今天是2016年08月01日。sql語句

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項目

相關文章
相關標籤/搜索