MySQL是一款非常流行的數(shù)據(jù)庫(kù)管理系統(tǒng),它支持存儲(chǔ)和處理各種類型的數(shù)據(jù),包括日期和時(shí)間數(shù)據(jù)。當(dāng)我們將時(shí)間數(shù)據(jù)存儲(chǔ)到MySQL中時(shí),它通常會(huì)將其存儲(chǔ)為UTC時(shí)間(協(xié)調(diào)世界時(shí))。但是,有時(shí)我們希望在查詢數(shù)據(jù)時(shí),將其轉(zhuǎn)換為不同的時(shí)區(qū)。在這篇文章中,我們將介紹如何在MySQL中存儲(chǔ)時(shí)間并自動(dòng)將其轉(zhuǎn)換為所需的時(shí)區(qū)。
在MySQL中,我們可以使用兩種類型的時(shí)間數(shù)據(jù)類型:DATETIME和TIMESTAMP。DATETIME是一個(gè)固定的日期和時(shí)間值,它以'YYYY-MM-DD HH:MM:SS'格式存儲(chǔ)。TIMESTAMP也是一個(gè)日期和時(shí)間值,但它只在范圍內(nèi)存儲(chǔ),并在需要時(shí)進(jìn)行轉(zhuǎn)換。 TIMESTAMP以'YYYY-MM-DD HH:MM:SS'格式存儲(chǔ),并且可以存儲(chǔ)與時(shí)區(qū)無(wú)關(guān)的UTC時(shí)間。
當(dāng)我們將時(shí)間數(shù)據(jù)插入MySQL表時(shí),MySQL會(huì)將其存儲(chǔ)為UTC時(shí)間。我們可以通過(guò)使用CONVERT_TZ函數(shù)將其轉(zhuǎn)換為所需的時(shí)區(qū)。例如,如果我們將數(shù)據(jù)插入帶有以下定義的表中:
CREATE TABLE `mytable` ( `id` int(11) NOT NULL AUTO_INCREMENT, `mytime` datetime NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
我們可以像這樣插入一條記錄:
INSERT INTO mytable (mytime) VALUES ('2022-01-01 15:00:00');
為了將UTC時(shí)間轉(zhuǎn)換為我們需要的時(shí)區(qū),我們可以使用CONVERT_TZ函數(shù),并將UTC時(shí)間和目標(biāo)時(shí)區(qū)作為參數(shù)傳遞:
SELECT CONVERT_TZ(mytime, '+00:00', '+08:00') AS mytime FROM mytable;
在這個(gè)例子中,我們將UTC時(shí)間轉(zhuǎn)換為東八區(qū)的時(shí)間。這個(gè)查詢將返回以下結(jié)果:
+---------------------+ | mytime | +---------------------+ | 2022-01-01 23:00:00 | +---------------------+
使用CONVERT_TZ函數(shù)可以使我們輕松地在MySQL中存儲(chǔ)和查詢時(shí)間數(shù)據(jù),并將其轉(zhuǎn)換為所需的時(shí)區(qū)。但是,請(qǐng)記住,在將數(shù)據(jù)存儲(chǔ)到MySQL中之前,最好將其轉(zhuǎn)換為UTC時(shí)間,以便您能夠更容易地進(jìn)行比較和排序。