Mysql中DATE_SUB函數


轉自:https://www.cnblogs.com/mr-wuxiansheng/p/7520214.html

在對數據查詢或菜單時經常要對指定的時間或時間段進行查詢,例如要查詢一天內的信息,要查詢一周內的信息,要查詢一個月內的. 

定義和用法

DATE_SUB() 函數從日期減去指定的時間間隔。

1.語法

DATE_SUB(date,INTERVAL expr type)
date 參數是合法的日期表達式。 expr 參數是您希望添加的時間間隔。
type 參數可以是下列值:
Type 值
MICROSECOND
SECOND
MINUTE
HOUR
DAY
WEEK
MONTH
QUARTER
YEAR
SECOND_MICROSECOND
MINUTE_MICROSECOND
MINUTE_SECOND
HOUR_MICROSECOND
HOUR_SECOND
HOUR_MINUTE
DAY_MICROSECOND
DAY_SECOND
DAY_MINUTE
DAY_HOUR
YEAR_MONTH

簡單實例

假設我們有如下的表:

 

OrderId ProductName OrderDate
1 'Computer' 2012-12-29 16:25:46.635
現在,我們希望從 "OrderDate" 減去 2 天。
我們使用下面的 SELECT 語句:
SELECT OrderId,DATE_SUB(OrderDate,INTERVAL 2 DAY) AS OrderPayDate  FROM Orders  
結果:
OrderId OrderPayDate
1 2012-12-27 16:25:46.635
3.復雜實例:

查詢一天:
    select * from table where to_days(column_time) = to_days(now());
    select * from table where date(column_time) = curdate(); 
查詢一周:
    select * from table where DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(column_time);
查詢一個月:
    select * from table where DATE_SUB(CURDATE(), INTERVAL 1 MONTH) <= date(column_time);
查詢指定天數
    select * from table where DATE_SUB(CURDATE(), INTERVAL 2 DAY) <= date(column_time);
 

我們可以根據我們不用的需要,使用不用的type,例如,我們要查詢兩周內的訂單,那我們可以這樣表達.
SELECT * FROM Orders where DATE_SUB(CURDATE(),INTERVAL 2 WEEK) <= date(column_time) 
就這么簡單


免責聲明!

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



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