適合新手的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!

推薦閱讀: