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')
-- 返回值是11CURDATE()
-- 用法:返回今日的日期,不包括時分秒, 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)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
mysql中secure_file_priv=不生效問題及解決
這篇文章主要介紹了mysql中secure_file_priv=不生效問題及解決方案,以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家,2024-01-01
MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要區(qū)別整理
這篇文章主要介紹了MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要區(qū)別整理,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-08-08
MySQL千萬級大表進行數(shù)據(jù)清理的幾種常見方案
當MySQL數(shù)據(jù)庫中的表數(shù)據(jù)量達到千萬級別時,直接對數(shù)據(jù)進行刪除操作將面臨嚴重的性能問題,可能會導致數(shù)據(jù)庫長時間的鎖表,因此,如何安全高效地進行數(shù)據(jù)清理成為一個亟需解決的問題,下面我將分享幾種常見的數(shù)據(jù)清理方案,需要的朋友可以參考下2023-11-11
mysql 查看當前使用的配置文件my.cnf的方法(推薦)
下面小編就為大家?guī)硪黄猰ysql 查看當前使用的配置文件my.cnf的方法(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04
win10下安裝兩個MySQL5.6.35數(shù)據(jù)庫
這篇文章主要為大家詳細介紹了win10下兩個MySQL5.6.35數(shù)據(jù)庫安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05
MySQL中實現(xiàn)插入或更新操作(類似Oracle的merge語句)
這篇文章主要介紹了在MySQL中實現(xiàn)插入或更新操作(類似Oracle的merge語句)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-09-09
asp.net 將圖片上傳到mysql數(shù)據(jù)庫的方法
圖片通過asp.net上傳到mysql數(shù)據(jù)庫的方法2009-06-06

