1. 程式人生 > >mysql獲取當前時間,前一天,後一天

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

原文  ---------> https://blog.csdn.net/csdn_ds/article/details/71728164

負責的專案中,使用的是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 DATE_FORMAT(NOW(),’%b %d %Y %h:%i %p’);
  • 顯示當前日期的年月日:SELECT DATE_FORMAT(NOW(),’%Y-%m-%d’);
  • W3Cshcool中關於  mysql中函式的講解   http://www.w3school.com.cn/sql/sql_dates.asp

備註:

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

結果類似:

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

js中如果顯示的是毫秒數或者不規則的時間可以先將時間轉化一下

 function formateDate(str){
            var  datenow=new Date(str);
            var xdate=datenow.getFullYear()+"-"+(datenow.getMonth()+1)+"-"+datenow.getDate();
            return xdate;

   }

獲取一個時間的  後  8天

function fun_submit(arg){ var date1 = new Date(); var xdate=date1.getFullYear()+"-"+(date1.getMonth()+1)+"-"+date1.getDate(); Date.parse(xdate.replace()); var date2 = new Date(date1); date2.setDate(date1.getDate()+8); var times = date2.getFullYear()+"-"+(date2.getMonth()+1)+"-"+date2.getDate(); alert(times); }