站長資訊網
        最全最豐富的資訊網站

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

        本篇文章給大家帶來了關于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;

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

        占位符 作用 占位符 作用
        %Y 年份 %m 月份
        %d 日期 %w 星期(數字)- (0為周日)
        %W 星期(名稱)- (英文) %j 本年的第幾天
        %U 本年的第幾周 %H 小時(24)
        %h 小時(12) %i 分鐘
        %s %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學習之日期函數的用法詳解

        日期計算的注意事項

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

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

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

        SELECT ename, hiredate, hiredate+1 FROM t_emp;

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

        日期偏移計算

        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視頻教程

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 久久亚洲私人国产精品| 1024国产欧美日韩精品| 国产精品亚洲片在线观看不卡 | 蜜国产精品jk白丝AV网站| 99R在线精品视频在线播放| jizz国产精品网站| 人妻少妇精品视频二区| 亚洲国产精品自在拍在线播放| 97视频在线精品国自产拍| 精品国产_亚洲人成在线高清| 久久精品国产亚洲av麻豆小说| 日本一区二区三区精品国产| 国产精品视频免费一区二区| 日韩精品在线视频| 国产亚洲精品国产| 国产麻豆精品久久一二三 | 国产精品亚洲专区无码WEB| 日韩精品国产自在久久现线拍| 国产精品露脸国语对白| 久久亚洲欧美国产精品| 亚洲国产另类久久久精品| 午夜精品久久久久久| 久久精品国产只有精品66 | 人妻少妇精品视频一区二区三区| 亚洲精品国产日韩无码AV永久免费网| 国产精品99| 国产精品无码DVD在线观看| 91精品观看91久久久久久| 久久99精品久久久久久| 国产精品素人搭讪在线播放| 国产综合色在线精品| 国产精品无码无在线观看| 久久精品国产清高在天天线| 精品性影院一区二区三区内射| 亚洲av午夜福利精品一区| 亚洲av无码乱码国产精品| 亚洲精品无码久久久影院相关影片| 一本大道无码日韩精品影视 | 欧美成人精品欧美一级乱黄一区二区精品在线| 国产综合成人色产三级高清在线精品发布 | 99久久国产综合精品成人影院|