欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年11月19日 10:04:42   作者:大唐冠軍侯  
這篇文章主要介紹了MySQL如何使用時間作為判斷條件,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

背景:在開發(fā)過程中,我們經常需要根據時間作為判斷條件來查詢數據,例如:當月,當日,當前小時,幾天內......

1. 當月

我們只需要使用一個mysql的MONTH(date)函數即可實現。(注意判斷年份)

MONTH(date);
-- 用法:MONTH函數返回一個整數,表示指定日期值的月份。

-- 舉例
SELECT MONTH('2020-11-11 00:00:00')
-- 返回值是11

2. 30天內

之所以把“30天內”放在當月的后面,是因為我經常會遇到這兩個需求相互轉換的情況,“30天內”也可以稱作“一個月內”。

這種情況我們需要使用DATEDIFF(expr1,expr2)函數。

DATEDIFF(expr1,expr2)
-- 用法:參數為兩個日期,返回的是expr1-expr2的天數差

-- 舉例
SELECT DATEDIFF('2020-11-01 08:00:00','2020-11-11 00:00:00')
-- 返回值是-10

3. 當日

當日需要使用TO_DAYS(date)函數。

TO_DAYS(date)
-- 用法:返回從0000年(公元1年)至當前日期的總天數。

-- 舉例
SELECT TO_DAYS('0000-01-01')
-- 返回值是1
SELECT TO_DAYS('0001-01-01')
-- 返回值是366

4. 當前小時

這種情況需要HOUR(date)和CURDATE()函數配合使用。

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天內

可以使用DATE_SUB(date,INTERVAL expr unit)函數來實現。

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之間用任意符號隔開

-- 舉例
-- 七天內的數據查詢
select * from table where created_at > DATE_SUB(CURDATE(),INTERVAL 7 DAY)

6. 多少天內數據統(tǒng)計

我們經常還會遇到這種需求,統(tǒng)計7天內每天數據的量。這種情況下,我們需要考慮沒有數據推送的情況,即為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查詢結果作為臨時表,匹配數據表統(tǒng)計多少天內的數據數量

-- 舉例:查詢12個月內每個月數據的數量
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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 面試中老生常談的MySQL問答集錦夯實基礎

    面試中老生常談的MySQL問答集錦夯實基礎

    這篇文章主要為大家介紹了面試中老生常談的MySQL問答集錦,不僅可以幫助大家順利通過面試更可以夯實大家的基礎,有需要的朋友可以借鑒參考下
    2022-03-03
  • mysql查詢結果輸出到文件的方法

    mysql查詢結果輸出到文件的方法

    下面小編就為大家?guī)硪黄猰ysql查詢結果輸出到文件的方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • Mysql獲取指定時間范圍數據的各種實例

    Mysql獲取指定時間范圍數據的各種實例

    最近在做管理后臺報表時,給定一個日期范圍,查出庫中這個日期范圍內的每一天數據,下面這篇文章主要給大家介紹了關于Mysql獲取指定時間范圍數據的相關資料,需要的朋友可以參考下
    2023-05-05
  • 簡單了解SQL常用刪除語句原理區(qū)別

    簡單了解SQL常用刪除語句原理區(qū)別

    這篇文章主要介紹了簡單了解SQL常用刪除語句原理區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-10-10
  • mySQL UNION運算符的默認規(guī)則研究

    mySQL UNION運算符的默認規(guī)則研究

    SQL UNION運算符的默認規(guī)則研究,學習union的朋友可以參考下。
    2009-07-07
  • win11系統(tǒng)下mysql8.4更改數據目錄問題解決

    win11系統(tǒng)下mysql8.4更改數據目錄問題解決

    更改數據庫目錄是指修改MySQL數據庫的存儲路徑,本文主要介紹了win11系統(tǒng)下mysql8.4更改數據目錄問題解決,具有一定的參考價值,感興趣的可以了解一下
    2024-07-07
  • MySql如何獲取相鄰數據

    MySql如何獲取相鄰數據

    這篇文章主要介紹了MySql如何獲取相鄰數據,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • windows下安裝mysql-8.0.18-winx64的教程(圖文詳解)

    windows下安裝mysql-8.0.18-winx64的教程(圖文詳解)

    這篇文章主要介紹了windows下安裝mysql-8.0.18-winx64,需要的朋友可以參考下
    2019-12-12
  • mysql 批處理文件出錯后繼續(xù)執(zhí)行的實現方法

    mysql 批處理文件出錯后繼續(xù)執(zhí)行的實現方法

    下面小編就為大家?guī)硪黄猰ysql 批處理文件出錯后繼續(xù)執(zhí)行的實現方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • MySQL實現分詞搜索(FULLTEXT)的方法

    MySQL實現分詞搜索(FULLTEXT)的方法

    這篇文章主要介紹了MySQL實現分詞搜索(FULLTEXT)的方法,包括全文搜索的簡單使用,建表添加FULLTEXT索引使用該技術非常簡單,首先需要有一張表,我建立了一張圖書表并插入了兩條數據,需要的朋友可以參考下
    2022-10-10

最新評論