首頁  >  文章  >  資料庫  >  MySQL學習之日期函數的用法詳解

MySQL學習之日期函數的用法詳解

WBOY
WBOY轉載
2022-08-15 18:29:411740瀏覽

這篇文章為大家帶來了關於mysql的相關知識,其中主要介紹了MySQL的日期函數,包括了獲取系統時間函數、日期格式化函數等等內容,下面一起來看一下,希望對大家有幫助。

MySQL學習之日期函數的用法詳解

推薦學習:mysql影片教學

# 取得系統時間函數

「NOW()」函數能夠取得目前系統日期和時間,格式如下:「YYYY-MM-DD hh:mm:ss」 (這裡的小時單位是24 小時制)

「CURDATE()」 函數能夠取得到目前系統的日期,格式如下:「YYYY-MM-DD」

「CURTIME()」 函數能夠取得目前系統時間,格式如下:「hh:mm:ss」 (24小時制)

SELECT NOW();            -- 返回结果 "2020-06-10 17:22:51"  (示例)
SELECT CURDATE();        -- 返回结果 "2020-06-10"
SELECT CURTIME();        -- 返回结果 "17:22:52"

日期格式化函數

"DATE_FORMAT()」 函數用於格式化日期,可以幫助我們擷取非常有用的日期資訊

語法如下:

DATE_FORMAT(日期, 表達式)

SELECT ename, DATE_FORMAT(hiredate,"%Y") AS "入职日期" FROM t_emp;

##作用##%m##%d日期%w#星期(數字)- (0為星期日)#%W星期(姓名)- (英文)%j本年的第幾天#%U本年的第幾週%H時(24)%h小時(12)%i分鐘#%s
佔位符
佔位符作用
%Y#h
##秒

# #%r

時間(24)

%T

# 時間(12)

 

 

日期函數練習

利用「日期函數」 ,查詢生日當天是週幾。

SELECT DATE_FORMAT("2018-01-01","%W");        -- 返回结果为 "Monday"

日期函數練習

利用 「日期函數」 ,查詢 1981 年上半年入職的員工人數有多少人?

SELECT COUNT(*)
FROM t_emp
WHERE DATE_FORMAT(hiredate,"%Y") = 1981
AND DATE_FORMAT(hiredate,"%m") <= 6;

日期計算的注意事項

在MySQL 中,兩個日期之間是不能夠直接進行相加或相減的;同時,日期也是不能夠與數字相加、減的。

原因在於,日期是一個特殊計算單位,而且進位之間也不是普通的十進制那樣。

雖然我們使用 日期 去進行 “ 1” 的操作不會產生語法上的錯誤,但是得到的結果是純數字,而不是我們想要的日期格式的結果。 (範例如下)

SELECT ename, hiredate, hiredate+1 FROM t_emp;

日期偏移量計算DATE_ADD() 函數可以實現日期的偏移計算,並且在時間單位的處理上,比較的靈活。

###語法如下:###
SELECT DATE_ADD("原始日期", INTERVAL, 偏移量, 时间单位)        -- INTERVAL 是 关键字
###"DATE_ADD() 函數" 示範案例如下###
SELECT DATE_ADD(NOW(), INTERVAL 10 DAY);         -- 得到的结果为 10 天 之后的日期时间
SELECT DATE_ADD(NOW(), INTERVAL -500 MINUTE);         -- 得到的结果为 500 分钟 之前的日期时间
SELECT DATE_ADD(DATE_ADD(NOW(), INTERVAL -6 MONTH), INTERVAL -3 DAY);         -- 得到的结果为 6 个月 3 天 之前的日期时间
SELECT 
DATE_FORMAT(
DATE_ADD(DATE_ADD(NOW(), INTERVAL -6 MONTH), INTERVAL -3 DAY) , "%Y-%m-%d") AS DATE;     -- 返回 "%Y-%m-%d" 格式结果
###計算日期之間相隔的天數######DATEDIFF() 函數用來計算兩個日期之間相差的天數,語法如下:#########DATEDIFF("日期", "日期")#########查詢10 部門中年收入超過15000且工齡超過20年的員工的資訊。 ###
SELECT empno, ename, sal, hiredate
FROM t_emp
WHERE deptno = 10 
AND (sal + IFNULL(comm,0)) * 12 >=15000
AND DATEDIFF(NOW(),hiredate)/365 >= 20

-- IFNULL(expr1,expr2):IFNULL 函数的语法,当第一个参数的值为null 的时候,则返回第二个参数的值
-- DATEDIFF(expr1,expr2):DATEDIFF 函数的语法,计算第一个日期与第二个日期的偏差时间差
-- NOW():NOW 函数可以获得当前日期
############推薦學習:###mysql影片教學######

以上是MySQL學習之日期函數的用法詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:jb51.net。如有侵權,請聯絡admin@php.cn刪除