MySQL中判斷日期間隔的方法


  MySQL中查詢一定時間間隔內的數據的方法比較常用,可以使用TO_DAYS、DATE_SUB等函數來實現。

TO_DAYS函數的作用是返回指定日期從0年開始計算的天數。

DATE_SUB函數的作用是通過指定日期減去指定間隔時間。

從而可以實現今天、昨天、最近7天(一周)、最近30天(1個月)、上個月等等查詢方法。例子如下:

  

1、今天

SELECT * FROM t1 WHERE TO_DAYS(adddate) = TO_DAYS(CURDATE());

 

2、昨天

SELECT * FROM t1 WHERE TO_DAYS(CURDATE()) - TO_DAYS(adddate) = 1;

 

3、最近7天

SELECT * FROM t1 WHERE adddate >= DATE_SUB(CURDATE(),INTERVAL 7 DAY);

 

4、最近30天

SELECT * FROM t1 WHERE adddate >= DATE_SUB(CURDATE(),INTERVAL 30 DAY);

 

5、上個月

SELECT * FROM t1 WHERE DATE_FORMAT(adddate,'%Y-%m') = DATE_FORMAT(DATE_SUB(curdate(), INTERVAL 1 MONTH),'%Y-%m');

 

PS:時間格式化部分可以查看:MySQL日期時間格式化參數

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM