濮阳杆衣贸易有限公司

主頁 > 知識庫 > MySQL如何使用時間作為判斷條件

MySQL如何使用時間作為判斷條件

熱門標簽:百度地圖圖標標注中心 日照旅游地圖標注 石家莊電商外呼系統(tǒng) 南通自動外呼系統(tǒng)軟件 廣東人工電話機器人 信陽穩(wěn)定外呼系統(tǒng)運營商 芒果電話機器人自動化 申請外呼電話線路 湖南人工外呼系統(tǒng)多少錢

背景:在開發(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查詢結果作為臨時表,匹配數(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)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Mysql字符串字段判斷是否包含某個字符串的2種方法
  • 驗證mysql是否安裝成功的方法
  • mysql插入前判斷數(shù)據(jù)是否存在的操作

標簽:公主嶺 阿里 惠州 呼和浩特 天津 牡丹江 沈陽 合肥

巨人網(wǎng)絡通訊聲明:本文標題《MySQL如何使用時間作為判斷條件》,本文關鍵詞  MySQL,如何,使用,時間,作為,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL如何使用時間作為判斷條件》相關的同類信息!
  • 本頁收集關于MySQL如何使用時間作為判斷條件的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    平潭县| 新蔡县| 芜湖县| 拉萨市| 阿拉善左旗| 玛纳斯县| 孝感市| 长岛县| 宽甸| 海原县| 寻乌县| 阳高县| 广河县| 岑巩县| 南京市| 眉山市| 定远县| 巍山| 广德县| 犍为县| 泸西县| 呼图壁县| 罗源县| 六盘水市| 辽阳市| 商城县| 蕉岭县| 德惠市| 赤城县| 浮山县| 霍邱县| 抚宁县| 江达县| 儋州市| 上杭县| 加查县| 郯城县| 通化县| 广东省| 白河县| 榆树市|