Mysql指定日期區間的提取方法
阿新 • • 發佈:2020-01-09
在資料庫搬磚的過程中,免不了要跟日期打交道,比如按日期彙總一些指標、統計某段時間內的總量等。
如果是固定的日期還好,只需直接指定即可,但很多時候都是需要根據當前日期自適應變化的。比如:提取上週一到上週日的資料、提取上個月的資料、提取前N個月的資料。。。
這些要求都有一個共同點,就是要視當前日期而定!那麼,我們就需要首先獲取當前日期的一些資訊,如當前日期是本週第幾天、本月第幾天等,然後,才能做下一步處理。
一、在提取所需日期區間之前,我們先介紹幾個常用的函式
-- 先執行這一句 SET @t = '2018-07-26 11:41:29'; -- 再執行這一句 SELECT DATE(@t)當前日期,YEAR(@t) 年份,MONTH(@t)月份,WEEK(@t)本年第幾周,DAY(@t) 本月第幾天,HOUR(@t)小時,MINUTE(@t)分鐘,SECOND(@t)秒
執行出來,結果是這樣的:
二、下面介紹幾個常用的日期加減運算函式
1、ADDDATE(expr,days) / SUBDATE(expr,days):
ADDDAT函式有兩個形參,第一個是基準日期,也即需要運算的日期;第二個是一個間隔表示式,形如:INTERVAL 1 HOUR,其中INTERVAL 是間隔的意思,中間的數字1可以換成任意整數,第三個hour可以替換成day/month/year等時間單位。
SUBDATE同理,只不過變成了減法運算。
完整的用法如下:
SELECT ADDDATE('2018-07-26 11:41:29',INTERVAL 1 HOUR); SELECT SUBDATE('2018-07-26 11:41:29',INTERVAL 1 HOUR);
2、DATE_ADD() / DATE_SUB():
用法同ADDDATE(expr,days)。
三、日期區間擷取
接下來,利用上面介紹的日期函式的用法,就可以進行日期區間的截取了。
1、上週
-- 提取上週的日期區間 SELECT CURDATE() NOW,ADDDATE(ADDDATE(DATE_SUB(CURDATE(),INTERVAL WEEKDAY(CURDATE()) + 1 DAY),-6),0) startdate,ADDDATE(DATE_SUB(CURDATE(),0) duetodate
2、上月
-- 上月 SELECT CURDATE() NOW,DATE_ADD(DATE_ADD(CURDATE(),INTERVAL -DAY(CURDATE())+1 DAY),INTERVAL -1 MONTH) startdate,INTERVAL -DAY(CURDATE()) DAY),INTERVAL 0 MONTH) duetodate
3、前四個月
-- 前四個月 SELECT CURDATE() NOW,ADDDATE(ADDDATE(CURDATE(),INTERVAL -4 MONTH) startdate,INTERVAL 0 MONTH) duetodate
4、上週四到本週三
有時候不是按照自然周進行統計的,需要自定義一週的起止日期,可以按照下面的方式:
SELECT ADDDATE(DATE_SUB(CURDATE(),INTERVAL (IF(WEEKDAY(CURDATE())IN(3,4,5,6),WEEKDAY(CURDATE()),WEEKDAY(CURDATE())+7 )) + 1 DAY),-3) startdate,3)duetodate
OK,至此就可以實現時間、日期的資訊提取、任意區間的截取了~
總結
以上所述是小編給大家介紹的Mysql指定日期區間的提取方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對我們網站的支援!