這篇文章為大家帶來了關於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;
佔位符 | ##作用|||
---|---|---|---|
佔位符 | 作用 | ||
%Y | #h | ##%m||
日期 | %w | #星期(數字)- (0為星期日) | |
星期(姓名)- (英文) | %j | 本年的第幾天 | |
本年的第幾週 | %H | 時(24) | |
小時(12) | %i | 分鐘 | |
##秒 |
時間(24)
%T# 時間(12) 日期函數練習利用「日期函數」 ,查詢生日當天是週幾。SELECT DATE_FORMAT("2018-01-01","%W"); -- 返回结果为 "Monday"
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 是 关键字
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" 格式结果
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學習之日期函數的用法詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!