MySQL?字符串日期格式轉(zhuǎn)換的幾種方法
在MySQL中,經(jīng)常需要將字符串類型的日期轉(zhuǎn)換成日期或時間類型,或者在不同的日期格式之間進行轉(zhuǎn)換。MySQL提供了幾種方法來實現(xiàn)這一點,包括使用STR_TO_DATE()
和DATE_FORMAT()
函數(shù)。
1. 使用STR_TO_DATE()函數(shù)
STR_TO_DATE()
函數(shù)可以將字符串轉(zhuǎn)換成日期或時間格式。它接受兩個主要參數(shù):要轉(zhuǎn)換的字符串和格式字符串。
語法:
STR_TO_DATE(str, format)
str
是要轉(zhuǎn)換的字符串。format
是該字符串的日期或時間格式。
示例:
假設(shè)你有一個日期字符串 '2023-04-01'
,并且它是以 'YYYY-MM-DD'
格式存儲的,但你希望將它轉(zhuǎn)換成日期類型以進行日期計算。
SELECT STR_TO_DATE('2023-04-01', '%Y-%m-%d') AS converted_date;
這將返回日期類型的結(jié)果,格式為 '2023-04-01'
。
2. 使用DATE_FORMAT()函數(shù)
DATE_FORMAT()
函數(shù)用于將日期或時間值格式化為指定的格式。雖然這主要用于格式化日期時間值,但你也可以用它來“轉(zhuǎn)換”日期到字符串的特定格式。
語法:
DATE_FORMAT(date, format)
date
是日期或時間值。format
是你希望返回的日期時間格式。
示例:
如果你有一個日期類型的值,并且希望將其格式化為 'YYYYMMDD'
格式的字符串。
SELECT DATE_FORMAT(NOW(), '%Y%m%d') AS formatted_date;
這里NOW()
函數(shù)返回當(dāng)前的日期和時間,然后DATE_FORMAT()
將其格式化為 'YYYYMMDD'
格式的字符串。
3. 轉(zhuǎn)換和格式化的結(jié)合使用
有時,你可能需要先將字符串轉(zhuǎn)換成日期類型,然后再將其格式化為另一種格式的字符串。這可以通過結(jié)合使用STR_TO_DATE()
和DATE_FORMAT()
來實現(xiàn)。
示例:
假設(shè)你有一個日期字符串 '01-Apr-2023'
,并且你希望將其轉(zhuǎn)換為 'YYYYMMDD'
格式的字符串。
SELECT DATE_FORMAT(STR_TO_DATE('01-Apr-2023', '%d-%b-%Y'), '%Y%m%d') AS formatted_string;
這里,STR_TO_DATE()
首先將字符串轉(zhuǎn)換為日期類型,然后使用DATE_FORMAT()
將其格式化為 'YYYYMMDD'
。
總結(jié)
通過STR_TO_DATE()
和DATE_FORMAT()
函數(shù),MySQL允許你在字符串和日期類型之間轉(zhuǎn)換,并在不同的日期格式之間自由轉(zhuǎn)換。這在進行數(shù)據(jù)清洗、處理和報表生成時非常有用。
起因
需要將Oracle中的數(shù)據(jù)導(dǎo)到MySQL中
阻礙
在Oracle導(dǎo)出數(shù)據(jù)時,發(fā)現(xiàn)導(dǎo)出的SQL腳本中的日期轉(zhuǎn)換是to_date('28-11-2023 14:15:17', 'dd-mm-yyyy hh24:mi:ss')
的形式,但MySQL并不認(rèn)識這個格式轉(zhuǎn)換函數(shù),此時需要將Oracle中這個日期轉(zhuǎn)換函數(shù)替換成MySQL中的日期格式轉(zhuǎn)換函數(shù)才能在MySQL中執(zhí)行導(dǎo)出的腳本,那么在MySQL中日期如何轉(zhuǎn)換呢?
分析
在to_date('28-11-2023 14:15:17', 'dd-mm-yyyy hh24:mi:ss')
中,是要將給定的字符串28-11-2023 14:15:17
按照dd-mm-yyyy hh24:mi:ss
的格式轉(zhuǎn)換成日期,那么我們也需要在MySQL找到一個函數(shù)能夠?qū)⒅付ǖ淖址凑找欢ǖ母袷睫D(zhuǎn)換成日期。
解決
在MySQL中可以使用str_to_date(str,format)
這個函數(shù)來實現(xiàn)將字符串按照時間格式轉(zhuǎn)換成日期。那么對于Oracle中的to_date('28-11-2023 14:15:17', 'dd-mm-yyyy hh24:mi:ss')
可以修改成str_to_date('28-11-2023 14:15:17', '%d-%m-%Y %H:%i:%s')
,替換后就可以在MySQL執(zhí)行進行日期轉(zhuǎn)換了。
驗證,結(jié)果如下:
總結(jié)
- Oracle中字符串轉(zhuǎn)日期:
to_date('28-11-2023 14:15:17', 'dd-mm-yyyy hh24:mi:ss')
- MySQL中字符串轉(zhuǎn)日期:
str_to_date('28-11-2023 14:15:17', '%d-%m-%Y %H:%i:%s')
- MySQL常見時間格式化:(與字符串中的對應(yīng)使用)
%Y: 年份,四位數(shù)字
%m:月份,兩位數(shù)字
%d: 日期,兩位數(shù)字
%H:小時(24小時制),兩位數(shù)字
%i: 分鐘,兩位數(shù)字
%s: 秒,兩位數(shù)字
- 擴展:MySQL中如果想將日期轉(zhuǎn)換成字符串可以使用
date_format(date,format)
到此這篇關(guān)于MySQL 字符串日期格式轉(zhuǎn)換的幾種方法的文章就介紹到這了,更多相關(guān)MySQL 字符串日期格式轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQl數(shù)據(jù)庫必知必會sql語句(加強版)
本文給大家分享了一篇關(guān)于mysql數(shù)據(jù)庫必會sql語句加強版內(nèi)容,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2017-04-04MySQL大內(nèi)存配置方案 如my-medium.ini、my-huge.ini等
這篇文章主要介紹了MySQL大內(nèi)存配置方案 如my-medium.ini、my-huge.ini等,經(jīng)測試確實不錯,訪問mysql速度快了很多2014-08-08php運行提示Can''t connect to MySQL server on ''localhost''的解決方法
有些時候我們運行php的時候,頁面提示Can't connect to MySQL server on 'localhost',那么就需要參考下面的方法來解決。2011-06-06MySQL實現(xiàn)批量更新不同表中的數(shù)據(jù)
這篇文章主要介紹了MySQL實現(xiàn)批量更新不同表中的數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05