MySQL如何使用時(shí)間作為判斷條件
背景:在開(kāi)發(fā)過(guò)程中,我們經(jīng)常需要根據(jù)時(shí)間作為判斷條件來(lái)查詢(xún)數(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)”也可以稱(chēng)作“一個(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')
-- 返回值是11CURDATE()
-- 用法:返回今日的日期,不包括時(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ù)來(lái)實(shí)現(xiàn)。
DATE_SUB(date,INTERVAL expr unit)
-- 用法:起始日期date 減去一個(gè)時(shí)間段后的日期
后面的單位unit有很多值可以選擇,如下表:
類(lèi)型(unit值) | 含義 | expr表達(dá)式的形式 |
---|---|---|
YEAR | 年 | YY |
MONTH | 月 | MM |
DAY | 日 | DD |
HOUR | 時(shí) | hh |
MINUTE | 分 | mm |
SECOND | 秒 | ss |
YEAR_MONTH | 年和月 | YY和MM之間用任意符號(hào)隔開(kāi) |
DAY_HOUR | 日和小時(shí) | DD和hh之間用任意符號(hào)隔開(kāi) |
DAY_MINUTE | 日和分鐘 | DD和mm之間用任意符號(hào)隔開(kāi) |
DAY_SECOND | 日和秒鐘 | DD和ss之間用任意符號(hào)隔開(kāi) |
HOUR_MINUTE | 時(shí)和分 | hh和mm之間用任意符號(hào)隔開(kāi) |
HOUR_SECOND | 時(shí)和秒 | hh和ss之間用任意符號(hào)隔開(kāi) |
MINUTE_SECOND | 分和秒 | mm和ss之間用任意符號(hào)隔開(kāi) |
-- 舉例
-- 七天內(nèi)的數(shù)據(jù)查詢(xún)
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ù)的量。這種情況下,我們需要考慮沒(méi)有數(shù)據(jù)推送的情況,即為0也要得到。
我的思路如下:
SELECT DATE_SUB( CURDATE(), INTERVAL m.s day ) AS orderDate FROM ( 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查詢(xún)結(jié)果作為臨時(shí)表,匹配數(shù)據(jù)表統(tǒng)計(jì)多少天內(nèi)的數(shù)據(jù)數(shù)量
-- 舉例:查詢(xún)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 date FROM ( 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)res left join table t on res.date = DATE_FORMAT(t.created_at,'%Y-%m') GROUP BY date
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
面試中老生常談的MySQL問(wèn)答集錦夯實(shí)基礎(chǔ)
這篇文章主要為大家介紹了面試中老生常談的MySQL問(wèn)答集錦,不僅可以幫助大家順利通過(guò)面試更可以夯實(shí)大家的基礎(chǔ),有需要的朋友可以借鑒參考下2022-03-03Mysql獲取指定時(shí)間范圍數(shù)據(jù)的各種實(shí)例
最近在做管理后臺(tái)報(bào)表時(shí),給定一個(gè)日期范圍,查出庫(kù)中這個(gè)日期范圍內(nèi)的每一天數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于Mysql獲取指定時(shí)間范圍數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2023-05-05簡(jiǎn)單了解SQL常用刪除語(yǔ)句原理區(qū)別
這篇文章主要介紹了簡(jiǎn)單了解SQL常用刪除語(yǔ)句原理區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10mySQL UNION運(yùn)算符的默認(rèn)規(guī)則研究
SQL UNION運(yùn)算符的默認(rèn)規(guī)則研究,學(xué)習(xí)union的朋友可以參考下。2009-07-07win11系統(tǒng)下mysql8.4更改數(shù)據(jù)目錄問(wèn)題解決
更改數(shù)據(jù)庫(kù)目錄是指修改MySQL數(shù)據(jù)庫(kù)的存儲(chǔ)路徑,本文主要介紹了win11系統(tǒng)下mysql8.4更改數(shù)據(jù)目錄問(wèn)題解決,具有一定的參考價(jià)值,感興趣的可以了解一下2024-07-07windows下安裝mysql-8.0.18-winx64的教程(圖文詳解)
這篇文章主要介紹了windows下安裝mysql-8.0.18-winx64,需要的朋友可以參考下2019-12-12mysql 批處理文件出錯(cuò)后繼續(xù)執(zhí)行的實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇mysql 批處理文件出錯(cuò)后繼續(xù)執(zhí)行的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10MySQL實(shí)現(xiàn)分詞搜索(FULLTEXT)的方法
這篇文章主要介紹了MySQL實(shí)現(xiàn)分詞搜索(FULLTEXT)的方法,包括全文搜索的簡(jiǎn)單使用,建表添加FULLTEXT索引使用該技術(shù)非常簡(jiǎn)單,首先需要有一張表,我建立了一張圖書(shū)表并插入了兩條數(shù)據(jù),需要的朋友可以參考下2022-10-10