MySQL如何使用時間作為判斷條件
背景:在開發(fā)過程中,我們經(jīng)常需要根據(jù)時間作為判斷條件來查詢數(shù)據(jù),例如:當(dāng)月,當(dāng)日,當(dāng)前小時,幾天內(nèi)......
1. 當(dāng)月
我們只需要使用一個mysql的MONTH(date)函數(shù)即可實現(xiàn)。(注意判斷年份)
MONTH(date);-- 用法:MONTH函數(shù)返回一個整數(shù),表示指定日期值的月份。
-- 舉例SELECT MONTH(’2020-11-11 00:00:00’)-- 返回值是11
2. 30天內(nèi)
之所以把“30天內(nèi)”放在當(dāng)月的后面,是因為我經(jīng)常會遇到這兩個需求相互轉(zhuǎn)換的情況,“30天內(nèi)”也可以稱作“一個月內(nèi)”。
這種情況我們需要使用DATEDIFF(expr1,expr2)函數(shù)。
DATEDIFF(expr1,expr2)-- 用法:參數(shù)為兩個日期,返回的是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)前小時
這種情況需要HOUR(date)和CURDATE()函數(shù)配合使用。
HOUR(date)-- 用法:返回當(dāng)前時間是今日的第幾個小時-- 舉例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天內(nèi)
可以使用DATE_SUB(date,INTERVAL expr unit)函數(shù)來實現(xiàn)。
DATE_SUB(date,INTERVAL expr unit)-- 用法:起始日期date 減去一個時間段后的日期
后面的單位unit有很多值可以選擇,如下表:
類型(unit值) 含義 expr表達(dá)式的形式 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之間用任意符號隔開
-- 舉例-- 七天內(nèi)的數(shù)據(jù)查詢select * from table where created_at > DATE_SUB(CURDATE(),INTERVAL 7 DAY)
6. 多少天內(nèi)數(shù)據(jù)統(tǒng)計
我們經(jīng)常還會遇到這種需求,統(tǒng)計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ù)據(jù)表統(tǒng)計多少天內(nèi)的數(shù)據(jù)數(shù)量
-- 舉例:查詢12個月內(nèi)每個月數(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
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 巧用SQL語言在ACCESS數(shù)據(jù)庫中批量替換內(nèi)容2. 如何實現(xiàn)MySQL數(shù)據(jù)庫的備份與恢復(fù)3. mybatis 為什么千萬不要使用 where 1=14. 數(shù)據(jù)庫相關(guān)的幾個技能:ACCESS轉(zhuǎn)SQL5. Microsoft Office Access設(shè)置小數(shù)位數(shù)的方法6. MySQL基本調(diào)度策略淺析7. Access數(shù)據(jù)庫日常維護(hù)方法(優(yōu)化)8. DB2 常用命令小結(jié)9. Mysql入門系列:安排預(yù)防性的維護(hù)MYSQL數(shù)據(jù)庫服務(wù)器10. Access數(shù)據(jù)庫提示OleDbException (0x80004005): 操作必須使用一個可更新的查詢

網(wǎng)公網(wǎng)安備