国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL如何使用時(shí)間作為判斷條件

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

背景:在開發(fā)過程中,我們經(jīng)常需要根據(jù)時(shí)間作為判斷條件來查詢數(shù)據(jù),例如:當(dāng)月,當(dāng)日,當(dāng)前小時(shí),幾天內(nèi)......

1. 當(dāng)月

我們只需要使用一個(gè)mysql的MONTH(date)函數(shù)即可實(shí)現(xiàn)。(注意判斷年份)

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

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

2. 30天內(nèi)

之所以把“30天內(nèi)”放在當(dāng)月的后面,是因?yàn)槲医?jīng)常會(huì)遇到這兩個(gè)需求相互轉(zhuǎn)換的情況,“30天內(nèi)”也可以稱作“一個(gè)月內(nèi)”。

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

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

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

3. 當(dāng)日

當(dāng)日需要使用TO_DAYS(date)函數(shù)。

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

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

4. 當(dāng)前小時(shí)

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

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

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

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

5. x天內(nèi)

可以使用DATE_SUB(date,INTERVAL expr unit)函數(shù)來實(shí)現(xiàn)。

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

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

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

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

6. 多少天內(nèi)數(shù)據(jù)統(tǒng)計(jì)

我們經(jīng)常還會(huì)遇到這種需求,統(tǒng)計(jì)7天內(nèi)每天數(shù)據(jù)的量。這種情況下,我們需要考慮沒有數(shù)據(jù)推送的情況,即為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查詢結(jié)果作為臨時(shí)表,匹配數(shù)據(jù)表統(tǒng)計(jì)多少天內(nèi)的數(shù)據(jù)數(shù)量

-- 舉例:查詢12個(gè)月內(nèi)每個(gè)月數(shù)據(jù)的數(shù)量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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 亚洲成人免费视频 | 美女一级免费毛片 | 99超级碰碰成人香蕉网 | 爽爽窝窝午夜精品一区二区 | 国产一级毛片网站 | 91精品网站 | 67194成人在线观看 | 拍拍拍又黄又爽无挡视频免费 | 精品一区二区久久久久久久网站 | 中文字幕乱码在线观看 | 久久精品人人爽人人爽快 | 亚洲欧洲日本天天堂在线观看 | 午夜一级毛片看看 | 131的美女午夜爱爱爽爽视频 | 韩国美女高清爽快一级毛片 | 免费特黄一级欧美大片在线看 | 欧美三级网站 | 成人在线视频免费 | 在线看黄网址 | 亚洲欧美综合国产不卡 | 亚欧成人 | 毛片在线看网站 | 国产精品久久久久久吹潮 | 一区二区精品在线观看 | 99re久久精品国产首页2020 | 欧美一级专区免费大片野外交 | 国产免费网 | 九九免费精品视频在这里 | 国产在线拍揄自揄视精品不卡 | 日韩偷拍自拍 | 久久久美女视频 | 91免费网站在线看入口黄 | 国产高清片| 亚洲国产剧情在线精品视 | 悟空影视大全免费影视 | 亚洲黄区 | 黄色作爱 | 9l国产精品久久久久麻豆 | 国内精品久久久久久久久久影视 | 欧美一级特黄aaa大片 | 国产精品久久久久久久久久免费 |