亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

MySQL如何使用時間作為判斷條件

瀏覽:4日期:2023-10-09 08:53:17

背景:在開發過程中,我們經常需要根據時間作為判斷條件來查詢數據,例如:當月,當日,當前小時,幾天內......

1. 當月

我們只需要使用一個mysql的MONTH(date)函數即可實現。(注意判斷年份)

MONTH(date);-- 用法:MONTH函數返回一個整數,表示指定日期值的月份。

-- 舉例SELECT MONTH(’2020-11-11 00:00:00’)-- 返回值是11

2. 30天內

之所以把“30天內”放在當月的后面,是因為我經常會遇到這兩個需求相互轉換的情況,“30天內”也可以稱作“一個月內”。

這種情況我們需要使用DATEDIFF(expr1,expr2)函數。

DATEDIFF(expr1,expr2)-- 用法:參數為兩個日期,返回的是expr1-expr2的天數差

-- 舉例SELECT DATEDIFF(’2020-11-01 08:00:00’,’2020-11-11 00:00:00’)-- 返回值是-10

3. 當日

當日需要使用TO_DAYS(date)函數。

TO_DAYS(date)-- 用法:返回從0000年(公元1年)至當前日期的總天數。

-- 舉例SELECT TO_DAYS(’0000-01-01’)-- 返回值是1 SELECT TO_DAYS(’0001-01-01’)-- 返回值是366

4. 當前小時

這種情況需要HOUR(date)和CURDATE()函數配合使用。

HOUR(date)-- 用法:返回當前時間是今日的第幾個小時-- 舉例SELECT HOUR(’2020-11-11 11:11:11’)-- 返回值是11

CURDATE()-- 用法:返回今日的日期,不包括時分秒, yyyy-MM-dd

-- 使用舉例select * from table where created_at > CURDATE() and HOUR(created_at) = HOUR(now())

5. x天內

可以使用DATE_SUB(date,INTERVAL expr unit)函數來實現。

DATE_SUB(date,INTERVAL expr unit)-- 用法:起始日期date 減去一個時間段后的日期

后面的單位unit有很多值可以選擇,如下表:

類型(unit值) 含義 expr表達式的形式 YEAR 年 YY MONTH 月 MM DAY 日 DD HOUR 時 hh MINUTE 分 mm SECOND 秒 ss YEAR_MONTH 年和月 YY和MM之間用任意符號隔開 DAY_HOUR 日和小時 DD和hh之間用任意符號隔開 DAY_MINUTE 日和分鐘 DD和mm之間用任意符號隔開 DAY_SECOND 日和秒鐘 DD和ss之間用任意符號隔開 HOUR_MINUTE 時和分 hh和mm之間用任意符號隔開 HOUR_SECOND 時和秒 hh和ss之間用任意符號隔開 MINUTE_SECOND 分和秒 mm和ss之間用任意符號隔開

-- 舉例-- 七天內的數據查詢select * from table where created_at > DATE_SUB(CURDATE(),INTERVAL 7 DAY)

6. 多少天內數據統計

我們經常還會遇到這種需求,統計7天內每天數據的量。這種情況下,我們需要考慮沒有數據推送的情況,即為0也要得到。

我的思路如下:

SELECT DATE_SUB( CURDATE(), INTERVAL m.s day ) AS orderDateFROM( SELECT 0 as s UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 ) m

以上面的sql查詢結果作為臨時表,匹配數據表統計多少天內的數據數量

-- 舉例:查詢12個月內每個月數據的數量SELECT COUNT(t.created_at),res.date FROM (SELECT DATE_FORMAT(DATE_SUB( CURDATE(), INTERVAL m.s MONTH ),’%Y-%m’) AS dateFROM( SELECT 0 as s UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL SELECT 8 UNION ALL SELECT 9 UNION ALL SELECT 10 UNION ALL SELECT 11 ) m)resleft join table t on res.date = DATE_FORMAT(t.created_at,’%Y-%m’)GROUP BY date

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 久久福利青草狠狠午夜 | 人人狠狠综合久久亚洲88 | 亚洲香蕉在线视频 | 欧美成a人片免费看久久 | 亚洲欧美制服丝袜一区二区三区 | 亚洲欧美日韩中文不卡 | 色婷婷久久免费网站 | 国产成人成人一区二区 | 黄在线免费观看 | 日韩精品一区二区三区小说 | 欧美成人免费毛片 | 国产三极| a黄毛片| 免费一级特黄特色大片在线观看看 | 欧美草比 | 久久精品亚洲精品一区 | 亚洲国产天堂在线网址 | 91高清视频| 免费一级做a爰片性视频 | 美女吊黑视频在线观看 | 国产换爱交换乱理伦片的功能 | 日本一级看片免费播放 | 久久一本精品久久精品66 | 国产亚洲精品看片在线观看 | 国产肉丝在线 | 免费久久一级欧美特大黄 | 亚洲乱亚洲乱妇无码 | 久久久久久久免费 | 亚洲精品永久www嫩草 | 精品视频一区二区三区在线观看 | 欧美精品亚洲精品日韩一区 | 国产网红精品 | 亚洲欧美日韩综合久久久久 | 亚洲精品色综合久久 | 亚洲欧美日韩一区超高清 | 日本免费专区 | 国产日本三级在线播放线观看 | 成人自拍视频在线观看 | 免费又爽又黄禁片观看1000 | 欧美人成人亚洲专区中文字幕 | 国产精品tv |