mysql日期条件如何应用_MySQL如何使用时间作为判断条件
背景:在開發(fā)過程中,我們經(jīng)常需要根據(jù)時間作為判斷條件來查詢數(shù)據(jù),例如:當月,當日,當前小時,幾天內(nèi)......
1. 當月
我們只需要使用一個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)”放在當月的后面,是因為我經(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. 當日
當日需要使用to_days(date)函數(shù)。
to_days(date)
-- 用法:返回從0000年(公元1年)至當前日期的總天數(shù)。
-- 舉例
select to_days('0000-01-01')
-- 返回值是1
select to_days('0001-01-01')
-- 返回值是366
4. 當前小時
這種情況需要hour(date)和curdate()函數(shù)配合使用。
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天內(nèi)
可以使用date_sub(date,interval expr unit)函數(shù)來實現(xiàn)。
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之間用任意符號隔開
-- 舉例
-- 七天內(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 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查詢結(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 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
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持萬仟網(wǎng)。
希望與廣大網(wǎng)友互動??
點此進行留言吧!
總結(jié)
以上是生活随笔為你收集整理的mysql日期条件如何应用_MySQL如何使用时间作为判断条件的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 延安看卵巢早衰最好的医院推荐
- 下一篇: 创维85a9电视能玩ps5吗