溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

發(fā)布時(shí)間:2022-11-08 09:54:50 來源:億速云 閱讀:137 作者:iii 欄目:MySQL數(shù)據(jù)庫(kù)

本篇內(nèi)容介紹了“MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

一、SQL時(shí)間存儲(chǔ)類型

首先要玩好處理時(shí)間的操作,要先明白此數(shù)據(jù)類型能夠干什么事,有什么用。MySQL中經(jīng)常用來存儲(chǔ)日期的數(shù)據(jù)類型有三種:Date、Datetime、Timestamp。

1.date

日歷日期,例如:‘2022-6-17’.format形式為:%Y-%m-%d。在其他語言中,像Python、JAVA等利用函數(shù)輸出Date都為yyyy-mm-dd的形式,業(yè)務(wù)精確到天就用這個(gè)格式。

2.datetime

具體時(shí)間日期 例如:'2022-6-17 17:00:22' format格式為:%Y-%m-%d %H:%M:%s.當(dāng)業(yè)務(wù)需求中需要精確到秒時(shí),可以用這個(gè)時(shí)間格式。

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

3.time

具體時(shí)間不包括日期,例如:'17:11:00' format格式為:%H:%M:%s。當(dāng)業(yè)務(wù)需求中只需要每天的時(shí)間,可以用這個(gè)時(shí)間格式。

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

4.timestamp

和datetime存儲(chǔ)類型一樣,也是既存儲(chǔ)時(shí)間又存儲(chǔ)日期。format格式為:%Y-%m-%d %H:%M:%s.

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

PS.datetime與timestamp的區(qū)別

  • 存儲(chǔ)方式不同,對(duì)于TIMESTAMP,它把客戶端插入的時(shí)間從當(dāng)前時(shí)區(qū)轉(zhuǎn)化為UTC(世界標(biāo)準(zhǔn)時(shí)間)進(jìn)行存儲(chǔ)。查詢時(shí),將其又轉(zhuǎn)化為客戶端當(dāng)前時(shí)區(qū)進(jìn)行返回。而對(duì)于DATETIME,不做任何改變,基本上是原樣輸入和輸出.

  • 存儲(chǔ)的時(shí)間范圍也不一樣timestamp所能存儲(chǔ)的時(shí)間范圍為:’1970-01-01 00:00:01.000000’ 到 ‘2038-01-19 03:14:07.999999’。 datetime所能存儲(chǔ)的時(shí)間范圍為:’1000-01-01 00:00:00.000000’ 到 ‘9999-12-31 23:59:59.999999’。

  • timestamp有一個(gè)機(jī)制是自動(dòng)初始化與更新,意思就是如果插入數(shù)據(jù)的時(shí)候沒有對(duì)該值進(jìn)行賦值,則自動(dòng)寫入當(dāng)前的[時(shí)間戳]對(duì)應(yīng)的格式。在更新其他字段的時(shí)候該自動(dòng)會(huì)自動(dòng)更新到當(dāng)前的時(shí)間

對(duì)比總結(jié)

  • timestamp和datetime除了存儲(chǔ)范圍和存儲(chǔ)方式不一樣,沒有太大區(qū)別。如果對(duì)于跨時(shí)區(qū)的業(yè)務(wù),TIMESTAMP更為合適

  • timestamp有自動(dòng)初始化和更新,當(dāng)你update某條記錄的時(shí)候,該列值會(huì)自動(dòng)更新,這是和datatime最大的區(qū)別

5.varchar/bigint

有時(shí)候存儲(chǔ)入庫(kù)格式不是固定的,可能出現(xiàn)入庫(kù)時(shí)間精確到日或者是小時(shí)又可能只有月,這種靈活不固定的時(shí)間就只能使用字符串或者是BIGINT這種類型格式來進(jìn)行。

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

這種就需要提取出來后期處理,轉(zhuǎn)換為時(shí)間格式進(jìn)行計(jì)算或者進(jìn)行邏輯運(yùn)算得到自己想要的時(shí)間。

二、獲取時(shí)間

1.now()

獲取當(dāng)?shù)鼐唧w日期和時(shí)間:

select now() as time

2.localtime()

獲取當(dāng)?shù)鼐唧w日期和時(shí)間,與now()一樣:

select LOCALTIME() as time

3.current_timestamp()

獲取當(dāng)?shù)鼐唧w日期和時(shí)間,與now()一樣:

select current_timestamp() as time

4.localtimestamp()

獲取當(dāng)?shù)鼐唧w日期和時(shí)間,與now()一樣:

select LOCALTIMESTAMP() as time

以上這4種函數(shù)功能都與now()功能一樣獲取當(dāng)?shù)鼐唧w日期和時(shí)間,平常使用一個(gè)now()就好了好記。

5.sysdate()

獲取當(dāng)?shù)鼐唧w日期和時(shí)間,與now()上述幾個(gè)函數(shù)不一樣的是,now()在執(zhí)行該函數(shù)之前就已得到了。

select sysdate() as time

以上函數(shù)均為獲取具體日期和時(shí)間。


6.curdate()

獲取當(dāng)?shù)鼐唧w日期:

select curdate() as time

7.current_time()

獲取當(dāng)?shù)鼐唧w日期,和curdate()函數(shù)功能一樣:

select current_date() as time

以上函數(shù)均為獲取具體日期。


8. curtime()

獲取具體的時(shí)間:

select curtime() as time

9.current_time()

獲取具體的時(shí)間:

select current_time() as

以上均為獲得具體時(shí)間的函數(shù)。


10. utc_date()

獲取UTC時(shí)間的日期,因?yàn)槲覀兪菛|八時(shí)區(qū)要快8個(gè)小時(shí),本地時(shí)間=UTC時(shí)間+8小時(shí)。

select utc_date() as time

由于博主現(xiàn)在是晚上九點(diǎn)所以還是6月17日,如果是早上八點(diǎn)之前就是6月16號(hào)了。

11.utc_time

獲取UTC時(shí)間的時(shí)間。

select utc_time() as time

12.utc_timestamp()

獲取UTC時(shí)間的具體日期和時(shí)間,在做跨國(guó)業(yè)務(wù)時(shí)非常有用。

select utc_timestamp() as time

以上為獲取UTC時(shí)間函數(shù)。


13.HOUR(SYSDATE())

獲取系統(tǒng)具體小時(shí):

select HOUR(SYSDATE()) as time

14.MINUTE(SYSDATE())

獲取當(dāng)前系統(tǒng)分鐘:

select MINUTE(SYSDATE()) as time

其他獲取year,month,day,second,microsecond都可以通過這種方法獲得,這里不再演示。

三、轉(zhuǎn)換時(shí)間

如果是用BIGINT或者是字符串varchar存儲(chǔ)的時(shí)間數(shù)據(jù)就需要將該列數(shù)據(jù)轉(zhuǎn)換為時(shí)間數(shù)據(jù),或者輸入一個(gè)字符串想要轉(zhuǎn)化為時(shí)間格式都需要轉(zhuǎn)換函數(shù),這里詳細(xì)介紹各種方法解決這種問題:

1.cast()

基礎(chǔ)語法格式:

cast( <數(shù)據(jù)> as <數(shù)據(jù)類型> )

可轉(zhuǎn)換的類型有字符串varchar、日期date、時(shí)間time、日期時(shí)間datetime、浮點(diǎn)型decimal、整數(shù)signed、無符號(hào)整數(shù)unsigned。

例如我們拿到展示的sql表格:MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

該列類型為BIGINT:

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

下面直接用cast轉(zhuǎn)換為時(shí)間類型:

select cast(time as date) as timefrom value_test

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

可見如果有與其他format不對(duì)應(yīng),只記錄到月或者記錄到小時(shí)時(shí),將不能識(shí)別轉(zhuǎn)為時(shí)間類型。也可以切換成time或是datetime:

select cast(time as datetime) as timefrom value_test

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

select cast(time as time) as timefrom value_test

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

只要是有6個(gè)字符的都會(huì)被識(shí)別為%H:%M:s。

我們可以修改表再看:

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

2.convert()

基礎(chǔ)語法格式:

convert(<數(shù)據(jù)>,<數(shù)據(jù)類型>)
select CONVERT(time ,date) as timefrom value_test

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

和上述cast的功能一樣,但是cast是強(qiáng)制轉(zhuǎn)換。

所以說如果涉及到記錄有多個(gè)不同維度的時(shí)間數(shù)據(jù)存儲(chǔ)的時(shí)候,一般是不用數(shù)據(jù)庫(kù)時(shí)間類型去做存儲(chǔ)的??碿ast的例子就可以看出。

3.str_to_date()

str_to_date()函數(shù)可以將時(shí)間格式的字符串按照所指定的顯示格式(format)轉(zhuǎn)換為不同的時(shí)間類型。

基礎(chǔ)語法格式:

str_to_date(<字符串>,<format格式>')
select str_to_date(time,'%Y%m%d') as timefrom value_test

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

這個(gè)函數(shù)自由性要比cast和convert的自由性高很多,可以自由定義format,但是不會(huì)僅顯示單個(gè)年或日,后面會(huì)根據(jù)字符的長(zhǎng)度補(bǔ)零填充:

select str_to_date(time,'%Y') as timefrom value_test

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

這里我們可以更改表格的時(shí)間觀察是否不滿足或者超過標(biāo)準(zhǔn)的時(shí)間格式能夠被識(shí)別:

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

select str_to_date(time,'%Y%m%d') as timefrom value_test

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

select str_to_date(time,'%Y%m%d%H%i%S') as timefrom value_test

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

可見兼容能力是很強(qiáng)的。

如果是時(shí)間都是統(tǒng)一格式記錄的直接使用cast或者convert快速轉(zhuǎn)換為時(shí)間格式就好了,若是記錄的有多個(gè)維度的時(shí)間應(yīng)該使用str_to_date函數(shù)來轉(zhuǎn)換。

四、時(shí)間轉(zhuǎn)換

時(shí)間轉(zhuǎn)換一般是把時(shí)間類似數(shù)據(jù)轉(zhuǎn)換為其他類型數(shù)據(jù),以上例子cast()函數(shù)和convert()函數(shù)都可以做到。改變一下位置就好了,由于上述已經(jīng)提到這里就做兩個(gè)簡(jiǎn)單的例子展示:

1.cast()

select cast(create_time as signed) as timefrom value_test

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

2.convert()

select convert(create_time ,signed) as timefrom value_test

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

3.date_format()

其實(shí)最主要的還是使用data_format(),date_format()函數(shù)可以以不同的格式顯示日期/時(shí)間數(shù)據(jù),可以實(shí)現(xiàn)日期轉(zhuǎn)換成字符串。也就是將時(shí)間數(shù)據(jù)讀取之后按照format形式轉(zhuǎn)換為字符串輸出,當(dāng)然轉(zhuǎn)換為了字符串我們又可以轉(zhuǎn)為其他的格式。

語法格式:

date_format(<時(shí)間類型數(shù)據(jù)>,<format格式>)

其中format的格式參數(shù)可選的有:

格式描述
%a星期名縮寫
%b月名縮寫
%c代表幾月的數(shù)值
%D帶時(shí)序后綴的數(shù)值-天
%d天數(shù),數(shù)值(00-31)
%e天數(shù),數(shù)值(0-31)
%f微秒
%H小時(shí) (00-23)
%h小時(shí) (01-12)
%I小時(shí) (01-12)
----------------------------
%i分鐘,數(shù)值(00-59)
%j轉(zhuǎn)換為天數(shù) (001-366)
%k小時(shí) (0-23)
%l小時(shí) (1-12)
%M月名
%m月,數(shù)值(00-12)
%pAM 或 PM
%r時(shí)間,12-小時(shí)(hh:mm:ss AM 或 PM)
%S秒(00-59)
%s秒(00-59)%T時(shí)間, 24-小時(shí) (hh:mm:ss)
-------------------------------
%U從年初首周開始計(jì)算 (00-53)  星期日是一周的第一天
%u從年初首周開始計(jì)算 (00-53)  星期一是一周的第一天
%V周 (01-53) 星期日是一周的第一天,與 %X 使用
------------------------------
%v周 (01-53) 星期一是一周的第一天,與 %x 使用
%W星期名
%w當(dāng)前周的天數(shù),(0=星期日, 6=星期六)
%X年,其中的星期日是周的第一天,4 位,與 %V 使用
%x年,其中的星期一是周的第一天,4 位,與 %v 使用
----------------------------
%Y年,4 位
%y年,2 位

自己大家可自己隨意組合使用:

select date_format(create_time, '%x%v') as timefrom value_test

MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么

但是記住轉(zhuǎn)換輸出的都為字符串,轉(zhuǎn)換為其他類型都需要再次轉(zhuǎn)換.

“MySQL獲取時(shí)間、格式轉(zhuǎn)換各類操作的方法是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI