婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Mysql指定日期區間的提取方法

Mysql指定日期區間的提取方法

熱門標簽:商家地圖標注哪個好 陜西400電話如何申請 承德電腦地圖標注 德惠市地圖標注 遵義地圖標注app 深圳 地圖標注賺錢真假 外呼系統從哪買 合肥營銷外呼系統收費

在數據庫搬磚的過程中,免不了要跟日期打交道,比如按日期匯總一些指標、統計某段時間內的總量等。

如果是固定的日期還好,只需直接指定即可,但很多時候都是需要根據當前日期自適應變化的。比如:提取上周一到上周日的數據、提取上個月的數據、提取前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) / SUBDATE(expr, days)。

三、日期區間截取

接下來,利用上面介紹的日期函數的用法,就可以進行日期區間的截取了。

1、上周

-- 提取上周的日期區間
SELECT CURDATE() NOW,
ADDDATE(ADDDATE(DATE_SUB(CURDATE(),INTERVAL WEEKDAY(CURDATE()) + 1 DAY),-6),0) startdate,
ADDDATE(DATE_SUB(CURDATE(),INTERVAL WEEKDAY(CURDATE()) + 1 DAY),0) duetodate

2、上月

-- 上月
SELECT CURDATE() NOW, 
DATE_ADD(DATE_ADD(CURDATE(),INTERVAL -DAY(CURDATE())+1 DAY), INTERVAL -1 MONTH) startdate,
DATE_ADD(DATE_ADD(CURDATE(),INTERVAL -DAY(CURDATE()) DAY), INTERVAL 0 MONTH) duetodate

3、前四個月

-- 前四個月
SELECT CURDATE() NOW, 
ADDDATE(ADDDATE(CURDATE(),INTERVAL -DAY(CURDATE())+1 DAY), INTERVAL -4 MONTH) startdate,
DATE_ADD(DATE_ADD(CURDATE(),INTERVAL -DAY(CURDATE()) DAY), 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
, ADDDATE(DATE_SUB(CURDATE(),INTERVAL (IF(WEEKDAY(CURDATE())IN(3,4,5,6),WEEKDAY(CURDATE()),WEEKDAY(CURDATE())+7 )) + 1 DAY),3)duetodate

OK,至此就可以實現時間、日期的信息提取、任意區間的截取了~

總結

以上所述是小編給大家介紹的Mysql指定日期區間的提取方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

您可能感興趣的文章:
  • Mysql中實現提取字符串中的數字的自定義函數分享

標簽:南陽 揚州 貴州 新余 贛州 商丘 巴中 三門峽

巨人網絡通訊聲明:本文標題《Mysql指定日期區間的提取方法》,本文關鍵詞  Mysql,指定,日期區,間的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Mysql指定日期區間的提取方法》相關的同類信息!
  • 本頁收集關于Mysql指定日期區間的提取方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 兰州市| 翁源县| 潜江市| 阜阳市| 富平县| 鹿邑县| 石渠县| 中宁县| 广宗县| 双流县| 竹山县| 克东县| 南靖县| 南溪县| 东安县| 鄂温| 克什克腾旗| 黑龙江省| 林口县| 屏东市| 武夷山市| 宁波市| 郧西县| 安乡县| 扎鲁特旗| 闽清县| 阿巴嘎旗| 金溪县| 霍林郭勒市| 正宁县| 青河县| 尉犁县| 咸宁市| 新民市| 池州市| 衡阳县| 勐海县| 靖安县| 辉南县| 诸城市| 车致|