最近在用mybatis時發現,將LocalDateTime插入到數據庫時時間少了8小時。
用網上其他方法試了不少,比如修改mysql時區,都不能解決。最后發現是JDBC連接的參數寫錯了。
經常在網上看到jdbc連接里邊有這樣一個參數&serverTimezone=UTC。這個UTC是協調世界時,我們中國在東八區,也就是UTC+8,和UTC差了8個小時。2021Java面試寶典
這就是為什么時間插入數據庫后少了8小時的原因。那么中國的時區是多少呢?在java.time.ZoneId這個類的幫助文檔和源碼里寫有:
-
EST - -05:00
-
HST - -10:00
-
MST - -07:00
-
ACT - Australia/Darwin
-
AET - Australia/Sydney
-
AGT - America/Argentina/Buenos_Aires
-
ART - Africa/Cairo
-
AST - America/Anchorage
-
BET - America/Sao_Paulo
-
BST - Asia/Dhaka
-
CAT - Africa/Harare
-
CNT - America/St_Johns
-
CST - America/Chicago
-
CTT - Asia/Shanghai
-
EAT - Africa/Addis_Ababa
-
ECT - Europe/Paris
-
IET - America/Indiana/Indianapolis
-
IST - Asia/Kolkata
-
JST - Asia/Tokyo
-
MIT - Pacific/Apia
-
NET - Asia/Yerevan
-
NST - Pacific/Auckland
-
PLT - Asia/Karachi
-
PNT - America/Phoenix
-
PRT - America/Puerto_Rico
-
PST - America/Los_Angeles
-
SST - Pacific/Guadalcanal
-
VST - Asia/Ho_Chi_Minh
可以看到CTT - Asia/Shanghai,所以我們在jdbc的連接里使用&serverTimezone=CTT就可以正確的插入時間了。
比較簡單的一個問題,有多少胖友碰到過呀?