適合新手的mysql日期類型轉換實例教程
1、使用cast() 和 convert() 函數實現日期格式的轉換
語法格式:
convert( 表達式,數據類型 )
cast( 表達式 as 數據類型 )
可轉換的類型有 字符串char、日期date、時間time、日期時間datetime、浮點型decimal、整數signed、無符號整數unsigned。
mysql> select cast(now() as signed); +-----------------------+ | cast(now() as signed) | +-----------------------+ | 20201030042922 | +-----------------------+ 1 row in set (0.00 sec) mysql> select convert(now(),signed); +-----------------------+ | convert(now(),signed) | +-----------------------+ | 20201030042933 | +-----------------------+ 1 row in set (0.00 sec) mysql> select cast(now() as char); +---------------------+ | cast(now() as char) | +---------------------+ | 2020-10-30 04:29:44 | +---------------------+
2、使用date_format()函數實現日期格式的轉換
date_format()函數可以以不同的格式顯示日期/時間數據,可以實現日期轉換成字符串。
語法格式:
date_format(date,format)
date為合法的日期,format為規定日期/時間的輸出格式。
可以使用的格式有:
格式 | 描述 |
---|---|
%a | 縮寫星期名 |
%b | 縮寫月名 |
%c | 月,數值 |
%D | 帶有英文前綴的月中的天 |
%d | 月的天,數值(00-31) |
%e | 月的天,數值(0-31) |
%f | 微秒 |
%H | 小時 (00-23) |
%h | 小時 (01-12) |
%I | 小時 (01-12) |
%i | 分鐘,數值(00-59) |
%j | 年的天 (001-366) |
%k | 小時 (0-23) |
%l | 小時 (1-12) |
%M | 月名 |
%m | 月,數值(00-12) |
%p | AM 或 PM |
%r | 時間,12-小時(hh:mm:ss AM 或 PM) |
%S | 秒(00-59) |
%s | 秒(00-59) |
%T | 時間, 24-小時 (hh:mm:ss) |
%U | 周 (00-53) 星期日是一周的第一天 |
%u | 周 (00-53) 星期一是一周的第一天 |
%V | 周 (01-53) 星期日是一周的第一天,與 %X 使用 |
%v | 周 (01-53) 星期一是一周的第一天,與 %x 使用 |
%W | 星期名 |
%w | 周的天 (0=星期日, 6=星期六) |
%X | 年,其中的星期日是周的第一天,4 位,與 %V 使用 |
%x | 年,其中的星期一是周的第一天,4 位,與 %v 使用 |
%Y | 年,4 位 |
%y | 年,2 位 |
示例1:時間類型轉換成字符串類型
mysql> select date_format(now(),'%Y-%m-%d'); +-------------------------------+ | date_format(now(),'%Y-%m-%d') | +-------------------------------+ | 2020-10-30 | +-------------------------------+
示例2:從學生表 ‘student’ 中查詢前2人現在的年齡。
mysql> select * from student limit 2; +------------+-----------+-----+------------+-----------------------+---------+ | Sid | Sname | Sex | Brithdate | Specialty | AScores | +------------+-----------+-----+------------+-----------------------+---------+ | 2011216001 | 趙成剛 | 男 | 1992-05-05 | 計算機應用技術 | 405.0 | | 2011216002 | 李婧 | 女 | 1992-01-06 | 計算機應用技術 | 395.5 | +------------+-----------+-----+------------+-----------------------+---------+ mysql> select sname, -> convert(date_format(now(),'%Y'),signed)-convert(date_format(Brithdate,'%Y'),signed) as '年齡' -> from student -> limit 2; +-----------+--------+ | sname | 年齡 | +-----------+--------+ | 趙成剛 | 28 | | 李婧 | 28 | +-----------+--------+
3、使用str_to_date()函數實現字符串類型轉換日期類型
str_to_date()函數可以將時間格式的字符串按照所指定的顯示格式(format)轉換為不同的時間類型。
語法格式:
str_to_date(date,format)
mysql> select str_to_date('2020-10-3','%Y-%m-%d'); +-------------------------------------+ | str_to_date('2020-10-3','%Y-%m-%d') | +-------------------------------------+ | 2020-10-03 | +-------------------------------------+ mysql> select str_to_date('2020-10-3','%Y'); +-------------------------------+ | str_to_date('2020-10-3','%Y') | +-------------------------------+ | 2020-00-00 | +-------------------------------+ mysql> select str_to_date('10:11','%H:%i:%S'); +---------------------------------+ | str_to_date('10:11','%H:%i:%S') | +---------------------------------+ | 10:11:00 | +---------------------------------+
把字符串轉換為日期時間需要註意以下幾點:
待轉換字符串中隻能出現數字,否則返回結果為 null;
如果格式字符串僅包含日期,則待轉字符串至少需要 8 位數字,轉換時默認前四位是年份,中間兩位是月份,最後兩位是日期,格式字符串無需使用 – 區分日期各部分,結果會自動用 – 拼接日期各個部分;
轉換後日期時間必須有效,否則返回結果為 null;
如果被轉字符串超出 8 位且格式字符串中無時間格式,則自動取前 8 位轉換為日期;
格式字符串可包含時間格式,格式字符串無需使用 : 區分時間各部分,結果中的時間部分會自動用 : 連接各個部分。
str_to_date() 函數的用法和 date_format() 基本一致,隻是輸出數據的類型不同,前提都需要熟悉輸出格式,參照date_format() 。
總結
到此這篇關於mysql日期類型轉換的文章就介紹到這瞭,更多相關mysql日期類型轉換內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- MySQL函數date_format()日期格式轉換的實現
- MySQL 字符串轉換為數字的方法小結
- MySQL教程DML數據操縱語言示例詳解
- mysql觸發器實時檢測一條語句進行備份刪除思路詳解
- MySQL中字段類型為longtext的值導出後顯示二進制串方式