麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

Mysql指定日期區(qū)間的提取方法

2024-07-25 19:08:44
字體:
供稿:網(wǎng)友

在數(shù)據(jù)庫搬磚的過程中,免不了要跟日期打交道,比如按日期匯總一些指標(biāo)、統(tǒng)計(jì)某段時間內(nèi)的總量等。

如果是固定的日期還好,只需直接指定即可,但很多時候都是需要根據(jù)當(dāng)前日期自適應(yīng)變化的。比如:提取上周一到上周日的數(shù)據(jù)、提取上個月的數(shù)據(jù)、提取前N個月的數(shù)據(jù)。。。

這些要求都有一個共同點(diǎn),就是要視當(dāng)前日期而定!那么,我們就需要首先獲取當(dāng)前日期的一些信息,如當(dāng)前日期是本周第幾天、本月第幾天等,然后,才能做下一步處理。

一、在提取所需日期區(qū)間之前,我們先介紹幾個常用的函數(shù)

-- 先運(yùn)行這一句SET @t = '2018-07-26 11:41:29';-- 再運(yùn)行這一句SELECT DATE(@t)當(dāng)前日期,YEAR(@t) 年份, MONTH(@t)月份,WEEK(@t)本年第幾周, DAY(@t) 本月第幾天, HOUR(@t)小時, MINUTE(@t)分鐘, SECOND(@t)秒

運(yùn)行出來,結(jié)果是這樣的:

Mysql,日期,區(qū)間,提取

二、下面介紹幾個常用的日期加減運(yùn)算函數(shù)

1、ADDDATE(expr, days) / SUBDATE(expr, days):

ADDDAT函數(shù)有兩個形參,第一個是基準(zhǔn)日期,也即需要運(yùn)算的日期;第二個是一個間隔表達(dá)式,形如:INTERVAL 1 HOUR,其中INTERVAL 是間隔的意思,中間的數(shù)字1可以換成任意整數(shù),第三個hour可以替換成day/month/year等時間單位。

SUBDATE同理,只不過變成了減法運(yùn)算。

完整的用法如下:

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)。

三、日期區(qū)間截取

接下來,利用上面介紹的日期函數(shù)的用法,就可以進(jìn)行日期區(qū)間的截取了。

1、上周

-- 提取上周的日期區(qū)間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、上周四到本周三

有時候不是按照自然周進(jìn)行統(tǒng)計(jì)的,需要自定義一周的起止日期,可以按照下面的方式:

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,至此就可以實(shí)現(xiàn)時間、日期的信息提取、任意區(qū)間的截取了~

總結(jié)

以上所述是小編給大家介紹的Mysql指定日期區(qū)間的提取方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識閱讀請移步到MYSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 色悠悠久久久久 | 亚洲成人免费电影 | 国产伦精品一区二区三区 | 一级做a爰性色毛片免费1 | 成人免费观看av | 亚洲一区中文字幕 | 一级大黄毛片免费观看 | 毛片视频在线免费观看 | 黄色大片在线免费观看 | 黄色大片网| 暴力肉体进入hdxxxx古装 | 国产在线色 | 日韩视频观看 | 日韩视| 永久免费不卡在线观看黄网站 | 日本aaa一级片 | 欧美一级高清片在线 | 欧美激情在线播放 | 欧美一级美国一级 | 日本大片在线播放 | 极品美女一级毛片 | 色播视频在线播放 | 国产做爰 | 久久爽久久爽久久av东京爽 | 黄色成人小视频 | 最新91在线视频 | 黑色丝袜美美女被躁视频 | 色蜜桃av| 色就色 综合偷拍区91网 | 一区二区三区视频在线观看 | 成人一级视频 | 国产乱淫a∨片免费观看 | 成人444kkkk在线观看 | 91久久另类重口变态 | av在线久草| 精品一区二区三区中文字幕老牛 | 激情小说色 | 久久精品无码一区二区三区 | 天海翼四虎精品正在播放 | 久久国产精品一区 | 国产日韩一区二区三区在线观看 |