適合新手的mysql日期類型轉(zhuǎn)換實(shí)例教程
1、使用cast() 和 convert() 函數(shù)實(shí)現(xiàn)日期格式的轉(zhuǎn)換
語(yǔ)法格式:
convert( 表達(dá)式,數(shù)據(jù)類型 )
cast( 表達(dá)式 as 數(shù)據(jù)類型 )
可轉(zhuǎn)換的類型有 字符串char、日期date、時(shí)間time、日期時(shí)間datetime、浮點(diǎn)型decimal、整數(shù)signed、無(wú)符號(hào)整數(shù)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()函數(shù)實(shí)現(xiàn)日期格式的轉(zhuǎn)換
date_format()函數(shù)可以以不同的格式顯示日期/時(shí)間數(shù)據(jù),可以實(shí)現(xiàn)日期轉(zhuǎn)換成字符串。
語(yǔ)法格式:
date_format(date,format)
date為合法的日期,format為規(guī)定日期/時(shí)間的輸出格式。
可以使用的格式有:
格式 | 描述 |
---|---|
%a | 縮寫星期名 |
%b | 縮寫月名 |
%c | 月,數(shù)值 |
%D | 帶有英文前綴的月中的天 |
%d | 月的天,數(shù)值(00-31) |
%e | 月的天,數(shù)值(0-31) |
%f | 微秒 |
%H | 小時(shí) (00-23) |
%h | 小時(shí) (01-12) |
%I | 小時(shí) (01-12) |
%i | 分鐘,數(shù)值(00-59) |
%j | 年的天 (001-366) |
%k | 小時(shí) (0-23) |
%l | 小時(shí) (1-12) |
%M | 月名 |
%m | 月,數(shù)值(00-12) |
%p | AM 或 PM |
%r | 時(shí)間,12-小時(shí)(hh:mm:ss AM 或 PM) |
%S | 秒(00-59) |
%s | 秒(00-59) |
%T | 時(shí)間, 24-小時(shí) (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:時(shí)間類型轉(zhuǎn)換成字符串類型
mysql> select date_format(now(),'%Y-%m-%d'); +-------------------------------+ | date_format(now(),'%Y-%m-%d') | +-------------------------------+ | 2020-10-30 | +-------------------------------+
示例2:從學(xué)生表 ‘student’ 中查詢前2人現(xiàn)在的年齡。
mysql> select * from student limit 2; +------------+-----------+-----+------------+-----------------------+---------+ | Sid | Sname | Sex | Brithdate | Specialty | AScores | +------------+-----------+-----+------------+-----------------------+---------+ | 2011216001 | 趙成剛 | 男 | 1992-05-05 | 計(jì)算機(jī)應(yīng)用技術(shù) | 405.0 | | 2011216002 | 李婧 | 女 | 1992-01-06 | 計(jì)算機(jī)應(yīng)用技術(shù) | 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()函數(shù)實(shí)現(xiàn)字符串類型轉(zhuǎn)換日期類型
str_to_date()函數(shù)可以將時(shí)間格式的字符串按照所指定的顯示格式(format)轉(zhuǎn)換為不同的時(shí)間類型。
語(yǔ)法格式:
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 | +---------------------------------+
把字符串轉(zhuǎn)換為日期時(shí)間需要注意以下幾點(diǎn):
待轉(zhuǎn)換字符串中只能出現(xiàn)數(shù)字,否則返回結(jié)果為 null;
如果格式字符串僅包含日期,則待轉(zhuǎn)字符串至少需要 8 位數(shù)字,轉(zhuǎn)換時(shí)默認(rèn)前四位是年份,中間兩位是月份,最后兩位是日期,格式字符串無(wú)需使用 - 區(qū)分日期各部分,結(jié)果會(huì)自動(dòng)用 - 拼接日期各個(gè)部分;
轉(zhuǎn)換后日期時(shí)間必須有效,否則返回結(jié)果為 null;
如果被轉(zhuǎn)字符串超出 8 位且格式字符串中無(wú)時(shí)間格式,則自動(dòng)取前 8 位轉(zhuǎn)換為日期;
格式字符串可包含時(shí)間格式,格式字符串無(wú)需使用 : 區(qū)分時(shí)間各部分,結(jié)果中的時(shí)間部分會(huì)自動(dòng)用 : 連接各個(gè)部分。
str_to_date() 函數(shù)的用法和 date_format() 基本一致,只是輸出數(shù)據(jù)的類型不同,前提都需要熟悉輸出格式,參照date_format() 。
總結(jié)
到此這篇關(guān)于mysql日期類型轉(zhuǎn)換的文章就介紹到這了,更多相關(guān)mysql日期類型轉(zhuǎn)換內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
安裝MySQL時(shí),輸入mysqld --install后,顯式該文件已存在問(wèn)題
這篇文章主要介紹了安裝MySQL時(shí),輸入mysqld --install后,顯式該文件已存在問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12使用SQL查詢所有數(shù)據(jù)庫(kù)名和表名問(wèn)題
這篇文章主要介紹了使用SQL查詢所有數(shù)據(jù)庫(kù)名和表名問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11Windows10下mysql 8.0.19 winx64安裝教程及修改初始密碼
這篇文章主要為大家詳細(xì)介紹了Windows10下mysql 8.0.19 winx64安裝教程及修改初始密碼,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02MySQL 數(shù)據(jù)表修復(fù)方法小結(jié)
本文主要介紹了MySQL 數(shù)據(jù)表修復(fù)方法小結(jié),使用REPAIR TABLE命令修復(fù)損壞,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-08-08MySQL Order by 語(yǔ)句用法與優(yōu)化詳解
Order by語(yǔ)句是用來(lái)排序的,經(jīng)常我們會(huì)使用到Order by來(lái)進(jìn)行排序,下面我給大家來(lái)講講Order by用法與優(yōu)化排序,有需要的同學(xué)可參考2013-06-06MySQL中使用load data命令實(shí)現(xiàn)數(shù)據(jù)導(dǎo)入的方法
MySQL支持load data命令的數(shù)據(jù)導(dǎo)入,該方式比直接的insert的效率要高,按照官方的說(shuō)法是要比insert語(yǔ)句快上20倍2013-10-10解讀索引列中有null值會(huì)不會(huì)使索引失效
這篇文章主要介紹了解讀索引列中有null值會(huì)不會(huì)使索引失效問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12MySQL中Update、select聯(lián)用操作單表、多表,及視圖與臨時(shí)表的區(qū)別
本篇文章給大家分享了MySQL中Update、select聯(lián)用操作單表、多表,及視圖與臨時(shí)表的區(qū)別,有興趣的朋友學(xué)習(xí)下吧。2018-06-06