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

        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號
        主站蜘蛛池模板: 国产亚洲精品va在线| 国产精品嫩草影院一二三区| 欧美精品免费在线| 亚洲精品蜜桃久久久久久| 国产高清在线精品一区二区三区| 久久久久久九九99精品| 老年人精品视频在线| 6080亚洲精品午夜福利| 国产精品伦一区二区三级视频| 亚洲人成国产精品无码| 精品久久久久久国产三级| 88久久精品无码一区二区毛片| 国产网红无码精品视频| 自拍偷在线精品自拍偷| 久久久久亚洲精品无码网址 | 91精品日韩人妻无码久久不卡| 国内精品久久久久影院日本| 亚洲国产精品一区二区久久hs | 天天爽夜夜爽夜夜爽精品视频| 国产观看精品一区二区三区| 久久最新精品国产| 99re这里只有精品热久久| 国产精品igao视频网| 久久亚洲日韩精品一区二区三区| 亚洲精品视频在线观看你懂的| 免费精品精品国产欧美在线欧美高清免费一级在线 | 日本精品自产拍在线观看中文| 精品国产成人在线| 国产精品亚洲产品一区二区三区 | 亚洲国产精品一区二区第一页| 日韩精品毛片| 偷拍精品视频一区二区三区| 久久久久国产成人精品亚洲午夜| 国产精品无码国模私拍视频| 国产成人精品亚洲精品| 国产叼嘿久久精品久久| 国产成人高清精品免费观看| 国产精品内射视频免费| 久久精品18| 日韩精品亚洲专区在线观看| 亚洲精品动漫人成3d在线|