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

        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號
        主站蜘蛛池模板: 亚洲欧洲精品无码AV| 午夜精品久久久久成人| 亚洲AV无码久久精品狠狠爱浪潮 | 久久亚洲国产成人精品无码区| 国内精品伊人久久久久网站| 日韩精品一二三区| 午夜精品福利视频| 久久se精品一区精品二区国产| 午夜成人精品福利网站在线观看 | 久久亚洲国产精品123区| 国产精品女人呻吟在线观看| 亚洲AV无码成人精品区狼人影院 | 欧美精品香蕉在线观看网| 免费看污污的网站欧美国产精品不卡在线观看 | 91精品在线国产| 真实国产乱子伦精品一区二区三区| 国产午夜无码精品免费看动漫| 亚洲综合一区二区精品导航| 69久久夜色精品国产69| 久久精品国产欧美日韩| 国产成人久久久精品二区三区| 永久无码精品三区在线4| 久久精品国产清自在天天线| 国产亚洲精品看片在线观看| 成人午夜精品久久久久久久小说 | 久久噜噜久久久精品66| 精品国产污污免费网站入口| 精品国产免费一区二区三区| 精品国产爽爽AV| 四虎成人精品| 最新国产成人精品2024| 亚洲精品成人无码中文毛片不卡| 亚洲精品无码AV人在线播放| 无码人妻精品一区二区三区久久久 | 国产精品夜色一区二区三区| 四虎影视永久在线精品| 久久这里只有精品视频99| 人妻少妇看A偷人无码精品| 中文精品99久久国产 | 国产成人亚洲精品影院| 国产精品亚洲精品日韩已方|