標籤:rda 資料 時間 rom 字元 擷取 val 表示 目前時間
負責的項目中,使用的是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:462016-08-0116:25:46
分類: Oracle資料庫
mysql擷取目前時間,前一天,後一天